Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Teleport 8.0 Test Plan #8665

Closed
Tracked by #8664
russjones opened this issue Oct 19, 2021 · 12 comments
Closed
Tracked by #8664

Teleport 8.0 Test Plan #8665

russjones opened this issue Oct 19, 2021 · 12 comments
Assignees
Milestone

Comments

@russjones
Copy link
Contributor

russjones commented Oct 19, 2021

Manual Testing Plan

Below are the items that should be manually tested with each release of Teleport.
These tests should be run on both a fresh install of the version to be released
as well as an upgrade of the previous version of Teleport.

  • Adding nodes to a cluster @atburke

    • Adding Nodes via Valid Static Token
    • Adding Nodes via Valid Short-lived Tokens
    • Adding Nodes via Invalid Token Fails
    • Revoking Node Invitation
  • Labels @atburke

    • Static Labels
    • Dynamic Labels
  • Trusted Clusters @atburke

    • Adding Trusted Cluster Valid Static Token
    • Adding Trusted Cluster Valid Short-lived Token
    • Adding Trusted Cluster Invalid Token
    • Removing Trusted Cluster
  • RBAC @codingllama

    Make sure that invalid and valid attempts are reflected in audit log.

    • Successfully connect to node with correct role
    • Unsuccessfully connect to a node in a role restricting access by label
    • Unsuccessfully connect to a node in a role restricting access by invalid SSH login
    • Allow/deny role option: SSH agent forwarding
    • Allow/deny role option: Port forwarding
  • Verify that custom PAM environment variables are available as expected. @xacrimon

  • Users @nklaassen
    With every user combination, try to login and signup with invalid second factor, invalid password to see how the system reacts.

    • Adding Users Password Only
    • Adding Users OTP
    • Adding Users U2F
    • Adding Users WebAuthn
    • Managing MFA devices
      • Add an OTP device with tsh mfa add
      • Add a U2F device with tsh mfa add
      • Verify that the U2F device works under WebAuthn
      • Add a WebAuthn device with tsh mfa add
      • List MFA devices with tsh mfa ls
      • Remove an OTP device with tsh mfa rm
      • Remove a U2F device with tsh mfa rm
      • Remove a WebAuthn device with tsh mfa rm
      • Attempt removing the last MFA device on the user
        • with second_factor: on in auth_service, should fail
        • with second_factor: optional in auth_service, should succeed
    • Login Password Only #8861
    • Login with MFA
      • Add 2 OTP and 2 WebAuthn devices with tsh mfa add
      • Login via OTP
      • Login via WebAuthn
    • Login OIDC
    • Login SAML
    • Login GitHub
    • Deleting Users
  • Backends @Joerger

    • Teleport runs with etcd
    • Teleport runs with dynamodb
    • Teleport runs with SQLite
    • Teleport runs with Firestore
  • Session Recording @codingllama

    • Session recording can be disabled
    • Sessions can be recorded at the node
      • Sessions in remote clusters are recorded in remote clusters
    • Sessions can be recorded at the proxy
      • Sessions on remote clusters are recorded in the local cluster
      • Enable/disable host key checking.
  • Audit Log @quinqu

    • Failed login attempts are recorded

    • Interactive sessions have the correct Server ID

      • Server ID is the ID of the node in "session_recording: node" mode
      • Server ID is the ID of the proxy in "session_recording: proxy" mode

      Node/Proxy ID may be found at /var/lib/teleport/host_uuid in the
      corresponding machine.

      Node IDs may also be queried via tctl nodes ls.

    • Exec commands are recorded

    • scp commands are recorded

    • Subsystem results are recorded

      Subsystem testing may be achieved using both
      Recording Proxy mode
      and
      OpenSSH integration.

      Assuming the proxy is proxy.example.com:3023 and node1 is a node running
      OpenSSH/sshd, you may use the following command to trigger a subsystem audit
      log:

      sftp -o "ProxyCommand ssh -o 'ForwardAgent yes' -p 3023 %[email protected] -s proxy:%h:%p" root@node1
  • Interact with a cluster using tsh @tcsc

    These commands should ideally be tested for recording and non-recording modes as they are implemented in a different ways.

    • tsh ssh <regular-node>
    • tsh ssh <node-remote-cluster>
    • tsh ssh -A <regular-node>
    • tsh ssh -A <node-remote-cluster>
    • tsh ssh <regular-node> ls
    • tsh ssh <node-remote-cluster> ls
    • tsh join <regular-node>
    • tsh join <node-remote-cluster>
    • tsh play <regular-node>
    • tsh play <node-remote-cluster>
    • tsh scp <regular-node>
    • tsh scp <node-remote-cluster>
    • tsh ssh -L <regular-node>
    • tsh ssh -L <node-remote-cluster>
    • tsh ls
    • tsh clusters
  • Interact with a cluster using ssh @quinqu
    Make sure to test both recording and regular proxy modes.

    • ssh <regular-node>
    • ssh <node-remote-cluster>
    • ssh -A <regular-node>
    • ssh -A <node-remote-cluster>
    • ssh <regular-node> ls
    • ssh <node-remote-cluster> ls
    • scp <regular-node>
    • scp <node-remote-cluster>
    • ssh -L <regular-node>
    • ssh -L <node-remote-cluster>
  • Interact with a cluster using the Web UI @tcsc

    • Connect to a Teleport node
    • Connect to a OpenSSH node
    • Check agent forwarding is correct based on role and proxy mode. (See note below - @tcsc)

User accounting @xacrimon

  • Verify that active interactive sessions are tracked in /var/run/utmp on Linux.
  • Verify that interactive sessions are logged in /var/log/wtmp on Linux.

Combinations @tcsc

For some manual testing, many combinations need to be tested. For example, for
interactive sessions the 12 combinations are below.

  • Connect to a OpenSSH node in a local cluster using OpenSSH.
  • Connect to a OpenSSH node in a local cluster using Teleport.
  • Connect to a OpenSSH node in a local cluster using the Web UI.
  • Connect to a Teleport node in a local cluster using OpenSSH.
  • Connect to a Teleport node in a local cluster using Teleport.
  • Connect to a Teleport node in a local cluster using the Web UI.
  • Connect to a OpenSSH node in a remote cluster using OpenSSH.
  • Connect to a OpenSSH node in a remote cluster using Teleport.
  • Connect to a OpenSSH node in a remote cluster using the Web UI.
  • Connect to a Teleport node in a remote cluster using OpenSSH.
  • Connect to a Teleport node in a remote cluster using Teleport.
  • Connect to a Teleport node in a remote cluster using the Web UI.

Teleport with EKS/GKE @smallinsky

  • Deploy Teleport on a single EKS cluster
  • Deploy Teleport on two EKS clusters and connect them via trusted cluster feature
  • Deploy Teleport Proxy outside of GKE cluster fronting connections to it (use this script to generate a kubeconfig)
  • Deploy Teleport Proxy outside of EKS cluster fronting connections to it (use this script to generate a kubeconfig)

Teleport with multiple Kubernetes clusters @r0mant

Note: you can use GKE or EKS or minikube to run Kubernetes clusters.
Minikube is the only caveat - it's not reachable publicly so don't run a proxy there.

  • Deploy combo auth/proxy/kubernetes_service outside of a Kubernetes cluster, using a kubeconfig
    • Login with tsh login, check that tsh kube ls has your cluster
    • Run kubectl get nodes, kubectl exec -it $SOME_POD -- sh
    • Verify that the audit log recorded the above request and session
  • Deploy combo auth/proxy/kubernetes_service inside of a Kubernetes cluster
    • Login with tsh login, check that tsh kube ls has your cluster
    • Run kubectl get nodes, kubectl exec -it $SOME_POD -- sh
    • Verify that the audit log recorded the above request and session
  • Deploy combo auth/proxy_service outside of the Kubernetes cluster and kubernetes_service inside of a Kubernetes cluster, connected over a reverse tunnel
    • Login with tsh login, check that tsh kube ls has your cluster
    • Run kubectl get nodes, kubectl exec -it $SOME_POD -- sh
    • Verify that the audit log recorded the above request and session
  • Deploy a second kubernetes_service inside of another Kubernetes cluster, connected over a reverse tunnel
    • Login with tsh login, check that tsh kube ls has both clusters
    • Switch to a second cluster using tsh kube login
    • Run kubectl get nodes, kubectl exec -it $SOME_POD -- sh on the new cluster
    • Verify that the audit log recorded the above request and session
  • Deploy combo auth/proxy/kubernetes_service outside of a Kubernetes cluster, using a kubeconfig with multiple clusters in it
    • Login with tsh login, check that tsh kube ls has all clusters
  • Test Kubernetes screen in the web UI (tab is located on left side nav on dashboard):
    • Verify that all kubes registered are shown with correct name and labels
    • Verify that clicking on a rows connect button renders a dialogue on manual instructions with Step 2 login value matching the rows name column
    • Verify searching for name or labels in the search bar works
    • Verify you can sort by name colum

Teleport with FIPS mode @russjones

  • Perform trusted clusters, Web and SSH sanity check with all teleport components deployed in FIPS mode.

ACME @Joerger

  • Teleport can fetch TLS certificate automatically using ACME protocol.

Migrations @r0mant @russjones

  • Migrate trusted clusters from 2.4.0 to 2.5.0
    • Migrate auth server on main cluster, then rest of the servers on main cluster
      SSH should work for both main and old clusters
    • Migrate auth server on remote cluster, then rest of the remote cluster
      SSH should work

Command Templates

When interacting with a cluster, the following command templates are useful:

OpenSSH

# when connecting to the recording proxy, `-o 'ForwardAgent yes'` is required.
ssh -o "ProxyCommand ssh -o 'ForwardAgent yes' -p 3023 %[email protected] -s proxy:%h:%p" \
  node.example.com

# the above command only forwards the agent to the proxy, to forward the agent
# to the target node, `-o 'ForwardAgent yes'` needs to be passed twice.
ssh -o "ForwardAgent yes" \
  -o "ProxyCommand ssh -o 'ForwardAgent yes' -p 3023 %[email protected] -s proxy:%h:%p" \
  node.example.com

# when connecting to a remote cluster using OpenSSH, the subsystem request is
# updated with the name of the remote cluster.
ssh -o "ProxyCommand ssh -o 'ForwardAgent yes' -p 3023 %[email protected] -s proxy:%h:%[email protected]" \
  node.foo.com

Teleport

# when connecting to a OpenSSH node, remember `-p 22` needs to be passed.
tsh --proxy=proxy.example.com --user=<username> --insecure ssh -p 22 node.example.com

# an agent can be forwarded to the target node with `-A`
tsh --proxy=proxy.example.com --user=<username> --insecure ssh -A -p 22 node.example.com

# the --cluster flag is used to connect to a node in a remote cluster.
tsh --proxy=proxy.example.com --user=<username> --insecure ssh --cluster=foo.com -p 22 node.foo.com

Teleport with SSO Providers @benarent

  • G Suite install instructions work
    • G Suite Screenshots are up to date
  • ActiveDirectoy install instructions work
    • Active Directoy Screenshots are up to date
  • Okta install instructions work
    • Okta Screenshots are up to date
  • OneLogin install instructions work
    • OneLogin Screenshots are up to date
  • OIDC install instructions work
    • OIDC Screenshots are up to date

Teleport Plugins @Joerger

  • Test receiving a message via Teleport Slackbot
  • Test receiving a new Jira Ticket via Teleport Jira

WEB UI @kimlisa @rudream @gzdunek

Main

For main, test with a role that has access to all resources.

Top Nav

  • Verify that cluster selector displays all (root + leaf) clusters
  • Verify that user name is displayed
  • Verify that user menu shows logout, help&support, and account settings (for local users)

Side Nav

  • Verify that each item has an icon
  • Verify that Collapse/Expand works and collapsed has icon >, and expand has icon v
  • Verify that it automatically expands and highlights the item on page refresh

Servers aka Nodes

  • Verify that "Servers" table shows all joined nodes
  • Verify that "Connect" button shows a list of available logins
  • Verify that "Hostname", "Address" and "Labels" columns show the current values
  • Verify that "Search" by hostname, address, labels works
  • Verify that terminal opens when clicking on one of the available logins
  • Verify that clicking on Add Server button renders dialogue set to Automatically view
    • Verify clicking on Regenerate Script regenerates token value in the bash command
    • Verify using the bash command successfully adds the server (refresh server list)
    • Verify that clicking on Manually tab renders manual steps
    • Verify that clicking back to Automatically tab renders bash command

Applications

  • Verify that clicking on Add Application button renders dialogue
    • Verify input validation (prevent empty value and invalid url)
    • Verify after input and clicking on Generate Script, bash command is rendered
    • Verify clicking on Regenerate button regenerates token value in bash command

Databases

  • Verify that clicking on Add Database button renders dialogue for manual instructions:
    • Verify selecting different options on Step 4 changes Step 5 commands

Active Sessions

  • Verify that "empty" state is handled
  • Verify that it displays the session when session is active
  • Verify that "Description", "Session ID", "Users", "Nodes" and "Duration" columns show correct values
  • Verify that "OPTIONS" button allows to join a session

Audit log

  • Verify that time range button is shown and works
  • Verify that clicking on Session Ended event icon, takes user to session player
  • Verify event detail dialogue renders when clicking on events details button
  • Verify searching by type, description, created works

Users

  • Verify that users are shown
  • Verify that creating a new user works
  • Verify that editing user roles works
  • Verify that removing a user works
  • Verify resetting a user's password works
  • Verify search by username, roles, and type works

Auth Connectors

  • Verify that creating OIDC/SAML/GITHUB connectors works
  • Verify that editing OIDC/SAML/GITHUB connectors works
  • Verify that error is shown when saving an invalid YAML
  • Verify that correct hint text is shown on the right side
  • Verify that encrypted SAML assertions work with an identity provider that supports it (Azure).

Auth Connectors Card Icons

  • Verify that GITHUB card has github icon
  • Verify that SAML card has SAML icon
  • Verify that OIDC card has OIDC icon
  • Verify when there are no connectors, empty state renders

Roles

  • Verify that roles are shown
  • Verify that "Create New Role" dialog works
  • Verify that deleting and editing works
  • Verify that error is shown when saving an invalid YAML
  • Verify that correct hint text is shown on the right side

Managed Clusters

  • Verify that it displays a list of clusters (root + leaf)
  • Verify that every menu item works: nodes, apps, audit events, session recordings.

Help & Support

  • Verify that all URLs work and correct (no 404)

Access Requests

Creating Access Requests

  1. Create a role with limited permissions (defined below as allow-roles). This role allows you to see the Role screen and ssh into all nodes.
  2. Create another role with limited permissions (defined below as allow-users). This role session expires in 4 minutes, allows you to see Users screen, and denies access to all nodes.
  3. Create another role with no permissions other than being able to create requests (defined below as default)
  4. Create a user with role default assigned
  5. Create a few requests under this user to test pending/approved/denied state.
kind: role
metadata:
  name: allow-roles
spec:
  allow:
    logins:
    - root
    node_labels:
      '*': '*'
    rules:
    - resources:
      - role
      verbs:
      - list
      - read
  options:
    max_session_ttl: 8h0m0s
version: v3
kind: role
metadata:
  name: allow-users
spec:
  allow:
    rules:
    - resources:
      - user
      verbs:
      - list
      - read
  deny:
    node_labels:
      '*': '*'
  options:
    max_session_ttl: 4m0s
version: v3
kind: role
metadata:
  name: default
spec:
  allow:
    request:
      roles:
      - allow-roles
      - allow-users
      suggested_reviewers:
      - random-user-1
      - random-user-2
  options:
    max_session_ttl: 8h0m0s
version: v3
  • Verify that creating a new request works
  • Verify that under requestable roles, only allow-roles and allow-users are listed
  • Verify input validation requires at least one role to be selected
  • Verify you can select/input/modify reviewers
  • Verify after creating, requests are listed in pending states
  • Verify you can't review own requests

Viewing & Approving/Denying Requests

Create a user with the role reviewer that allows you to review all requests, and delete them.

kind: role
version: v3
metadata:
  name: reviewer
spec:
  allow:
    review_requests:
      roles: ['*']
  • Verify you can view access request from request list
  • Verify there is list of reviewers you selected (empty list if none selected AND none wasn't defined in roles)
  • Verify threshold name is there (it will be default if thresholds weren't defined in role, or blank if not named)
  • Verify you can approve a request with message, and immediately see updated state with your review stamp (green checkmark) and message box
  • Verify you can deny a request, and immediately see updated state with your review stamp (red cross)
  • Verify deleting the denied request is removed from list

Assuming Approved Requests

  • Verify assume buttons are only present for approved request and for logged in user
  • Verify that assuming allow-roles allows you to see roles screen and ssh into nodes
  • Verify that after clicking on the assume button, it is disabled in both the list and in viewing
  • After assuming allow-roles, verify that assuming allow-users allows you to see users screen, and denies access to nodes
    • Verify a switchback banner is rendered with roles assumed, and count down of when it expires
    • Verify switching back goes back to your default static role
    • Verify after re-assuming this role, the user is automatically logged out after the expiry is met (4 minutes)
  • Verify that after logging out (or getting logged out automatically) and relogging in, permissions are reset to default, and requests that are not expired and are approved are assumable again

Access Request Waiting Room

Strategy Reason

Create the following role:

kind: role
metadata:
  name: restrict
spec:
  allow:
    request:
      roles:
      - <some other role to assign user after approval>
  options:
    max_session_ttl: 8h0m0s
    request_access: reason
    request_prompt: <some custom prompt to show in reason dialogue>
version: v3
  • Verify after login, reason dialogue is rendered with prompt set to request_prompt setting
  • Verify after clicking send request, pending dialogue renders
  • Verify after approving a request, dashboard is rendered
  • Verify the correct role was assigned

Strategy Always

With the previous role you created from Strategy Reason, change request_access to always:

  • Verify after login, pending dialogue is rendered
  • Verify after approving a request, dashboard is rendered
  • Verify after denying a request, access denied dialogue is rendered
  • Verify a switchback banner is rendered with roles assumed, and count down of when it expires
  • Verify switchback button says Logout and clicking goes back to the login screen

Strategy Optional

With the previous role you created from Strategy Reason, change request_access to optional:

  • Verify after login, dashboard is rendered

Terminal

  • Verify that top nav has a user menu (Main and Logout)
  • Verify that switching between tabs works on alt+[1...9]

Node List Tab

  • Verify that Cluster selector works (URL should change too)
  • Verify that Quick launcher input works
  • Verify that Quick launcher input handles input errors
  • Verify that "Connect" button shows a list of available logins
  • Verify that "Hostname", "Address" and "Labels" columns show the current values
  • Verify that "Search" by hostname, address, labels work
  • Verify that new tab is created when starting a session

Session Tab

  • Verify that session and browser tabs both show the title with login and node name
  • Verify that terminal resize works
    • Install midnight commander on the node you ssh into: $ sudo apt-get install mc
    • Run the program: $ mc
    • Resize the terminal to see if panels resize with it
  • Verify that session tab shows/updates number of participants when a new user joins the session
  • Verify that tab automatically closes on "$ exit" command
  • Verify that SCP Upload works
  • Verify that SCP Upload handles invalid paths and network errors
  • Verify that SCP Download works
  • Verify that SCP Download handles invalid paths and network errors

Session Player

  • Verify that it can replay a session
  • Verify that when playing, scroller auto scrolls to bottom most content
  • Verify when resizing player to a small screen, scroller appears and is working
  • Verify that error message is displayed (enter a invalid SID in the URL)

Invite Form

  • Verify that input validates
  • Verify that invite works with 2FA disabled
  • Verify that invite works with OTP enabled
  • Verify that invite works with U2F enabled
  • Verify that invite works with WebAuthn enabled
  • Verify that error message is shown if an invite is expired/invalid

Login Form

  • Verify that input validates
  • Verify that login works with 2FA disabled
  • Verify that changing passwords works for 2FA disabled
  • Verify that login works with OTP enabled
  • Verify that changing passwords works for OTP enabled
  • Verify that login works with U2F enabled
  • Verify that changing passwords works for U2F enabled
  • Verify that login works with WebAuthn enabled
  • Verify that changing passwords works for WebAuthn enabled
  • Verify that login works for Github/SAML/OIDC
  • Verify that account is locked after several unsuccessful attempts
  • Verify that redirect to original URL works after successful login

Multi-factor Authentication (mfa)

Create/modify teleport.yaml and set the following authentication settings under auth_service

authentication:
  type: local
  second_factor: optional
  require_session_mfa: yes
  webauthn:
    rp_id: example.com

MFA invite, login, password reset, change password

  • Verify during invite/reset, second factor list all auth types: none, hardware key, and authenticator app
  • Verify registration works with all option types
  • Verify login with all option types
  • Verify changing password with all option types
  • Change second_factor type to on and verify that mfa is required (no option none in dropdown)

MFA require auth

Go to Account Settings > Two-Factor Devices and register a new device

Using the same user as above:

  • Verify logging in with registered WebAuthn key works
  • Verify connecting to a ssh node prompts you to tap your registered WebAuthn key
  • Verify in the web terminal, you can scp upload/download files

MFA Management

  • Verify adding first device works without requiring re-authentication
  • Verify re-authenticating with a WebAuthn device works
  • Verify re-authenticating with a U2F device works
  • Verify re-authenticating with a OTP device works
  • Verify adding a WebAuthn device works
  • Verify adding a U2F device works
  • Verify adding an OTP device works
  • Verify removing a device works
  • Verify second_factor set to off disables adding devices

Cloud

Invite/Reset

  • Verify email as usernames, receives recovery codes
  • Verify non email usernames, receives no recovery codes

Recovery Code Management

  • Verify generating recovery codes for local accounts with email usernames works
  • Verify local accounts with non-email usernames are not able to generate recovery codes
  • Verify SSO accounts are not able to generate recovery codes

Recovery Flow: Add new mfa device

  • Verify recovering (adding) a new hardware key device with password
  • Verify recovering (adding) a new otp device with password
  • Verify viewing and deleting any old device (but not the one just added)
  • Verify new recovery codes are created at the end of flow

Recovery Flow: Change password

  • Verify recovering password with any mfa device
  • Verify new recovery codes are created at the end of flow

Recovery Email

  • Verify receiving email for link to start recovery
  • Verify receiving email for successfully recovering
  • Verify receiving email for locked account when max attempts reached

RBAC

Create a role, with no allow.rules defined:

kind: role
metadata:
  name: test
spec:
  allow:
    app_labels:
      '*': '*'
    logins:
    - root
    node_labels:
      '*': '*'
  options:
    max_session_ttl: 8h0m0s
version: v3
  • Verify that a user has access only to: "Servers", "Applications", "Databases", "Kubernetes", "Active Sessions", "Access Requests" and "Manage Clusters"
  • Verify there is no Add Server, Application, Databases, Kubernetes button in each respective view
  • Verify only Nodes, Apps, Databases, and Kubernetes are listed under options button in Manage Clusters

Note: User has read/create access_request access to their own requests, despite resource settings

Add the following under spec.allow.rules to enable read access to the audit log:

  - resources:
      - event
      verbs:
      - list
  • Verify that the Audit Log and Session Recordings is accessible
  • Verify that playing a recorded session is denied

Add the following to enable read access to recorded sessions

  - resources:
      - session
      verbs:
      - read
  • Verify that a user can re-play a session (session.end)

Add the following to enable read access to the roles

- resources:
      - role
      verbs:
      - list
      - read
  • Verify that a user can see the roles
  • Verify that a user cannot create/delete/update a role

Add the following to enable read access to the auth connectors

- resources:
      - auth_connector
      verbs:
      - list
      - read
  • Verify that a user can see the list of auth connectors.
  • Verify that a user cannot create/delete/update the connectors

Add the following to enable read access to users

  - resources:
      - user
      verbs:
      - list
      - read
  • Verify that a user can access the "Users" screen
  • Verify that a user cannot reset password and create/delete/update a user

Add the following to enable read access to trusted clusters

  - resources:
      - trusted_cluster
      verbs:
      - list
      - read
  • Verify that a user can access the "Trust" screen
  • Verify that a user cannot create/delete/update a trusted cluster.

Performance/Soak Test @fspmarshall @rosstimothy

Using tsh bench tool, perform the soak tests and benchmark tests on the following configurations:

  • Cluster with 10K nodes in normal (non-IOT) node mode with ETCD

  • Cluster with 10K nodes in normal (non-IOT) mode with DynamoDB

  • Cluster with 1K IOT nodes with ETCD

  • Cluster with 1K IOT nodes with DynamoDB

  • Cluster with 500 trusted clusters with ETCD

  • Cluster with 500 trusted clusters with DynamoDB

Soak Tests

Run 4hour soak test with a mix of interactive/non-interactive sessions:

tsh bench --duration=4h user@teleport-monster-6757d7b487-x226b ls
tsh bench -i --duration=4h user@teleport-monster-6757d7b487-x226b ps uax

Observe prometheus metrics for goroutines, open files, RAM, CPU, Timers and make sure there are no leaks

  • Verify that prometheus metrics are accurate.

Breaking load tests

Load system with tsh bench to the capacity and publish maximum numbers of concurrent sessions with interactive
and non interactive tsh bench loads.

Teleport with Cloud Providers

AWS @timothyb89

GCP @xacrimon

  • Deploy Teleport to GCP. Using Cloud Firestore & Cloud Storage
  • Deploy Teleport to GKE. Google Kubernetes engine.
  • Deploy Teleport Enterprise to GCP.

IBM @xacrimon

  • Deploy Teleport to IBM Cloud. Using IBM Database for etcd & IBM Object Store
  • Deploy Teleport to IBM Cloud Kubernetes.
  • Deploy Teleport Enterprise to IBM Cloud.

Application Access @r0mant @smallinsky

  • Run an application within local cluster.
    • Verify the debug application debug_app: true works.
    • Verify an application can be configured with command line flags.
    • Verify an application can be configured from file configuration.
    • Verify that applications are available at auto-generated addresses name.rootProxyPublicAddr and well as publicAddr.
  • Run an application within a trusted cluster.
    • Verify that applications are available at auto-generated addresses name.rootProxyPublicAddr.
  • Verify Audit Records.
    • app.session.start and app.session.chunk events are created in the Audit Log.
    • app.session.chunk points to a 5 minute session archive with multiple app.session.request events inside.
    • tsh play <chunk-id> can fetch and print a session chunk archive.
  • Verify JWT using verify-jwt.go.
  • Verify RBAC.
  • Verify CLI access with tsh app login.
  • Verify AWS console access.
    • Can log into AWS web console through the web UI.
    • Can interact with AWS using tsh aws commands.
  • Verify dynamic registration.
    • Can register a new app using tctl create.
    • Can update registered app using tctl create -f.
    • Can delete registered app using tctl rm.
  • Test Applications screen in the web UI (tab is located on left side nav on dashboard):
    • Verify that all apps registered are shown
    • Verify that clicking on the app icon takes you to another tab
    • Verify using the bash command produced from Add Application dialogue works (refresh app screen to see it registered)

Database Access @r0mant @smallinsky

  • Connect to a database within a local cluster.
    • Self-hosted Postgres.
    • Self-hosted MySQL.
    • Self-hosted MongoDB.
    • Self-hosted CockroachDB.
    • AWS Aurora Postgres.
    • AWS Aurora MySQL.
    • AWS Redshift.
    • GCP Cloud SQL Postgres.
    • GCP Cloud SQL MySQL.
  • Connect to a database within a remote cluster via a trusted cluster.
    • Self-hosted Postgres.
    • Self-hosted MySQL.
    • Self-hosted MongoDB.
    • Self-hosted CockroachDB.
    • AWS Aurora Postgres.
    • AWS Aurora MySQL.
    • AWS Redshift.
    • GCP Cloud SQL Postgres.
    • GCP Cloud SQL MySQL.
  • Verify audit events.
    • db.session.start is emitted when you connect.
    • db.session.end is emitted when you disconnect.
    • db.session.query is emitted when you execute a SQL query.
  • Verify RBAC.
    • tsh db ls shows only databases matching role's db_labels.
    • Can only connect as users from db_users.
    • (Postgres only) Can only connect to databases from db_names.
      • db.session.start is emitted when connection attempt is denied.
    • (MongoDB only) Can only execute commands in databases from db_names.
      • db.session.query is emitted when command fails due to permissions.
    • Can configure per-session MFA.
      • MFA tap is required on each tsh db connect.
  • Verify dynamic registration.
    • Can register a new database using tctl create.
    • Can update registered database using tctl create -f.
    • Can delete registered database using tctl rm.
  • Verify discovery.
    • Can detect and register RDS instances and Aurora clusters.
  • Test Databases screen in the web UI (tab is located on left side nav on dashboard):
    • Verify that all dbs registered are shown with correct name, description, type, and labels
    • Verify that clicking on a rows connect button renders a dialogue on manual instructions with Step 2 login value matching the rows name column
    • Verify searching for all columns in the search bar works
    • Verify you can sort by all columns except labels

Desktop Access @zmb3

  • Connect to statically defined desktop
  • Connect to desktop discovered via LDAP
  • User lock terminates desktop session
  • Session terminates after client idle timeout
  • Audit logs show session start/end
  • Hosts labeled appropriately via regexp
  • RBAC denies access due to labels
  • RBAC denies access due to Windows OS Login
  • Multiple sessions as different users on the same desktop are allowed
  • Can connect multiple windows_desktop_services to the same Teleport cluster and connect to desktops on different AD domains
  • Typing abcdefghijklmnopqrstuvwxyz1234567890-=!@#$%^&*()_+[]\{}|;':",./<>?~`, backspace, return and moving a cursor around with arrow keys works as expected with all supported browsers. Update: all other keys should now work. A known bug is that F11 (show desktop shortcut) doesn't work if you're on MacOS, as the OS seems to capture it and doesn't forward it to the browser. A useful tool for testing which keys are being registered on a windows machine is: https://dennisbabkin.com/kbdkeyinfo/
  • Left click and right clicks register as Windows clicks (right click on the desktop should show a Windows menu, not a Chrome one) on all supported browsers.

TLS Routing @r0mant

  • Verify that teleport proxy v2 configuration starts only a single listener.
    version: v2
    teleport:
      proxy_service:
        enabled: "yes"
        public_addr: ['root.example.com']
        web_listen_addr: 0.0.0.0:3080
    
  • Run Teleport Proxy in multiplex mode auth_service.proxy_listener_mode: "multiplex"
    • Trusted cluster
      • Setup trusted clusters using single port setup web_proxy_addr == tunnel_addr
      kind: trusted_cluster
      spec:
        ...
        web_proxy_addr: root.example.com:443
        tunnel_addr: root.example.com:443
        ...
      
  • Database Access
    • Verify that tsh db connect works through proxy running in multiplex mode
      • Postgres
      • MySQL
      • MongoDB
      • CockroachDB
    • Verify connecting to a database through TLS ALPN SNI local proxy tsh db proxy with a GUI client.
  • Application Access
    • Verify app access through proxy running in multiplex mode
  • SSH Access
    • Connect to a OpenSSH server through a local ssh proxy ssh -o "ForwardAgent yes" -o "ProxyCommand tsh proxy ssh %r@%h:%p" [email protected]
    • Connect to a OpenSSH server on leaf-cluster through a local ssh proxyssh -o "ForwardAgent yes" -o "ProxyCommand tsh proxy ssh --cluster=leaf-cluster %r@%h:%p" [email protected]
    • Verify tsh ssh access through proxy running in multiplex mode
  • Kubernetes access:
    • Verify kubernetes access through proxy running in multiplex mode
@russjones russjones self-assigned this Oct 19, 2021
@russjones russjones added this to the 8.0 milestone Oct 19, 2021
@zmb3
Copy link
Collaborator

zmb3 commented Nov 1, 2021

Desktop Access: Seeing the arrow keys map incorrectly on macOS client. Same behavior in Chrome, Safari, and Firefox. This is using the built-in MacBook keyboard.

  • left arrow is mapping to 4
  • right arrow is mapping to 6
  • up arrow is mapping to 8
  • down arrow is mapping to 2

This is addressed with #8791 which still needs to be backported (#8813).

@r0mant
Copy link
Collaborator

r0mant commented Nov 1, 2021

Potential K8s access issue when used via TLS routing. I get:

➜  ~ kubectl get nodes
Unable to connect to the server: x509: certificate is valid for mbp, root.gravitational.io, host.minikube.internal, localhost, remote.kube.proxy.teleport.cluster.local, host.minikube.internal, *.teleport.cluster.local, teleport.cluster.local, *.root.gravitational.io, *.host.minikube.internal, not kube.

I'm using kubernetes_service with kubeconfig_file (if that matters). cc @smallinsky

@zmb3
Copy link
Collaborator

zmb3 commented Nov 1, 2021

Desktop Access: disconnects due to client idle timeout fail to emit a disconnect event to the audit log (but otherwise disconnect correctly and emit a desktop session end event correctly). This is due to attempting to use the desktop ID as the event's "server ID."

Rejecting audit event client.disconnect("") from "3b581a11-b94a-4274-860b-8266868ca42e": 
server "3b581a11-b94a-4274-860b-8266868ca42e" can't emit event with 
server ID "foo-example-com". 

The server ID must be the Windows Desktop Service's HostUUID, otherwise the ValidateServerMetadata check will fail.

Fixed in #8828, which needs merge + backport.

@rosstimothy
Copy link
Contributor

rosstimothy commented Nov 2, 2021

etcd Load Tests

3 auth 2 proxy 1 node non-IoT

tsh bench --duration=30m root@loadtest-7fbf6bcbfc-b5l7l ls

* Requests originated: 17988
* Requests failed: 0

Histogram

Percentile Response Duration
---------- -----------------
25         1289 ms
50         1301 ms
75         1319 ms
90         1374 ms
95         1600 ms
99         1648 ms
100        2053 ms
tsh bench --interactive --duration=30m root@loadtest-7fbf6bcbfc-b5l7l ps aux

* Requests originated: 17987
* Requests failed: 0

Histogram

Percentile Response Duration
---------- -----------------
25         1301 ms
50         1314 ms
75         1330 ms
90         1352 ms
95         1388 ms
99         1724 ms
100        3553 ms

3 auth 2 proxy 1 node IoT

tsh bench --duration=30m root@loadtest-7fbf6bcbfc-ww7h8 ls

* Requests originated: 17987
* Requests failed: 0

Histogram

Percentile Response Duration
---------- -----------------
25         1314 ms
50         1326 ms
75         1340 ms
90         1359 ms
95         1381 ms
99         1561 ms
100        3329 ms
tsh bench --interactive --duration=30m root@loadtest-7fbf6bcbfc-ww7h8 ps aux

* Requests originated: 17987
* Requests failed: 0

Histogram

Percentile Response Duration
---------- -----------------
25         1302 ms
50         1314 ms
75         1328 ms
90         1344 ms
95         1363 ms
99         1457 ms
100        3479 ms

10k node non-IoT

8 0 0-beta 2-10k-etcd-non-IoT

Soak tests:

tsh bench --duration=30m root@loadtest-7fbf6bcbfc-52zdr ls 

* Requests originated: 17982
* Requests failed: 0

Histogram

Percentile Response Duration
---------- -----------------
25         1481 ms
50         1505 ms
75         1541 ms
90         1623 ms
95         1714 ms
99         1920 ms
100        3335 ms
tsh bench --interactive --duration=30m root@loadtest-7fbf6bcbfc-klws7 ps aux

* Requests originated: 17985
* Requests failed: 0

Histogram

Percentile Response Duration
---------- -----------------
25         1496 ms
50         1515 ms
75         1543 ms
90         1624 ms
95         1720 ms
99         1978 ms
100        4647 ms

10k nodes IoT

8 0 0 -beta 2-10k-etcd-IoT

Soak tests:

tsh bench --duration=30m root@loadtest-7fbf6bcbfc-47hh9 ls

* Requests originated: 17986
* Requests failed: 0

Histogram

Percentile Response Duration
---------- -----------------
25         1499 ms
50         1530 ms
75         1642 ms
90         1834 ms
95         1990 ms
99         2257 ms
100        4259 ms
tsh bench --interactive --duration=30m root@loadtest-7fbf6bcbfc-6gjnv ps aux

* Requests originated: 17982
* Requests failed: 0

Histogram

Percentile Response Duration
---------- -----------------
25         1527 ms
50         1558 ms
75         1682 ms
90         1897 ms
95         2035 ms
99         2249 ms
100        3143 ms

500 Trusted Clusters

image

zmb3 added a commit that referenced this issue Nov 2, 2021
We were attempting to use the desktop name as the server ID,
but in order to publish audit events we must use the HostUUID
of the windows_desktop_service.

Updates #8665
@timothyb89
Copy link
Contributor

Tested out several of the AWS deployment examples. Both Terraform examples worked fine with the 8.0.0-beta.2 AMIs (tested the simple example with the OSS AMIs, and the HA example with Enterprise).

The CloudFormation example seems very broken. I'm told it hasn't been maintained in quite a while and am not sure if we care to validate it here. Some of its issues:

  • Node processes needed to be manually restarted to pick up the CA pin change after fetching Let's Encrypt certs

  • The proxy load balancer doesn't forward port 3023 so tsh login hangs

  • With a load balancer rule manually added to expose 3023, tsh login still fails:

    Original Error: *trace.ConnectionProblemError Get &#34;https://teleport.cluster.local/v2/authorities/host?load_keys=false&#34;: ssh: rejected: connect failed (Cannot open new SSH session on reverse tunnel. Are you connecting to the right port?)
    

    (I gave up debugging here, I'm not sure if we care to get this example working again)

zmb3 added a commit that referenced this issue Nov 3, 2021
We were attempting to use the desktop name as the server ID,
but in order to publish audit events we must use the HostUUID
of the windows_desktop_service.

Updates #8665
zmb3 added a commit that referenced this issue Nov 3, 2021
We were attempting to use the desktop name as the server ID,
but in order to publish audit events we must use the HostUUID
of the windows_desktop_service.

Updates #8665
@zmb3
Copy link
Collaborator

zmb3 commented Nov 3, 2021

Desktop access: heartbeats for multiple Windows hosts discovered via LDAP all report the same host.

Issue #8846
Fixed in #8847

@russjones
Copy link
Contributor Author

Desktop Access: Investigate required libraries.

Issue #8765

@timothyb89
Copy link
Contributor

Just filed #8860 for my issues with the CloudFormation example, though given #8665 (comment), I wonder if I hit a similar issue.

@russjones
Copy link
Contributor Author

russjones commented Nov 5, 2021

Aggregate last 3 releases.

Backend Cluster Size Mode PTY 6.2 7.0 8.0
etcd 10k Regular No 49183 ms 56383 ms 4475 ms 3335 ms
etcd 10k Regular Yes 59423 ms 61215 ms 4507 ms 4647 ms
etcd 10k Tunnel No 65439 ms 53759 ms 4451 ms 4259 ms
etcd 10k Tunnel Yes 64924 ms 48223 ms 4435 ms 3143 ms
DynamoDB 10k Regular No
DynamoDB 10k Regular Yes
DynamoDB 10k Tunnel No
DynamoDB 10k Tunnel Yes
DynamoDB 1 Regular No 2471 ms 1824 ms
DynamoDB 1 Regular Yes 2081 ms 1483 ms
DynamoDB 1 Tunnel No 826 ms 2125 ms
DynamoDB 1 Tunnel Yes 518 ms 2002 ms

@tcsc
Copy link
Contributor

tcsc commented Nov 5, 2021

Re: Check agent forwarding is correct based on role and proxy mode.

  • WebUI allows Agent Forwarding when allowed by role
  • WebUI disallows Agent Forwarding when disallowed by role
  • WebUI allows agent forwarding in session recording modes off, proxy, node.
rec mode fwd allowed by role fwd not allowed by role
off allowed disallowed
proxy allowed conn failed
node allowed disallowed

Caveats:

I'm still not sure what Proxy Mode means in this context, but I've interpreted to to mean the session_recording mode. Even so, I am still not sure what the correct Agent Forwarding behaviour is for the different recording modes, or even how they should be expected to affect the Agent Forwarding modes.

Fully aware that I may have been testing the wrong thing, I considered something that looks like this to be "allowed":

agent-fwd-allowed

..and something that looks like this was considered "disallowed":

agent-fwd-denied

@smallinsky
Copy link
Contributor

ALPN Proxy + Reverse Tunnel fails when ACME is used:

Issue #8665 (comment)
Fixed in #8869

zmb3 added a commit that referenced this issue Nov 5, 2021
We were attempting to use the desktop name as the server ID,
but in order to publish audit events we must use the HostUUID
of the windows_desktop_service.

Updates #8665
zmb3 added a commit that referenced this issue Nov 9, 2021
We were attempting to use the desktop name as the server ID,
but in order to publish audit events we must use the HostUUID
of the windows_desktop_service.

Updates #8665
@fspmarshall
Copy link
Contributor

fspmarshall commented Nov 10, 2021

Dynamo (IoT)

10k Scaling

10k-iot-dynamo

Soak

tsh bench --duration=30m root@ip-172-31-11-250-us-west-2-compute-internal ls

* Requests originated: 17999
* Requests failed: 0

Histogram

Percentile Response Duration 
---------- ----------------- 
25         152 ms            
50         166 ms            
75         181 ms            
90         194 ms            
95         208 ms            
99         283 ms            
100        2125 ms
tsh bench --interactive --duration=30m root@ip-172-31-11-250-us-west-2-compute-internal ps aux

* Requests originated: 17999
* Requests failed: 0

Histogram

Percentile Response Duration 
---------- ----------------- 
25         159 ms            
50         169 ms            
75         179 ms            
90         192 ms            
95         207 ms            
99         284 ms            
100        2002 ms

Dynamo (non-IoT)

10k Scaling

10k-non-iot-dynamo

Soak

tsh bench --duration=30m root@ip-172-31-11-250-us-west-2-compute-internal ls

* Requests originated: 17999
* Requests failed: 0

Histogram

Percentile Response Duration 
---------- ----------------- 
25         145 ms            
50         154 ms            
75         164 ms            
90         176 ms            
95         188 ms            
99         237 ms            
100        1824 ms
tsh bench --interactive --duration=30m root@ip-172-31-11-250-us-west-2-compute-internal ps aux

* Requests originated: 17999
* Requests failed: 0

Histogram

Percentile Response Duration 
---------- ----------------- 
25         150 ms            
50         161 ms            
75         174 ms            
90         186 ms            
95         195 ms            
99         238 ms            
100        1483 ms

Dynamo (500 Trusted Cluster)

500-tc-dynamo


Notes

  • 500tc memory usage high due to failure to clean up sqlite databases for remote clusters: Remote cluster sqlite cache leak #8916
  • All soak command were run from bastion within the same network as the auth/proxy servers, and the target node. Previous tests were not necessarily done in this manner. Improved numbers are no representative of a real performance improvement.

zmb3 added a commit that referenced this issue Nov 10, 2021
We were attempting to use the desktop name as the server ID,
but in order to publish audit events we must use the HostUUID
of the windows_desktop_service.

Updates #8665
zmb3 added a commit that referenced this issue Nov 10, 2021
We were attempting to use the desktop name as the server ID,
but in order to publish audit events we must use the HostUUID
of the windows_desktop_service.

Updates #8665
@r0mant r0mant closed this as completed Nov 18, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

8 participants