Skip to content

Commit

Permalink
Merge pull request rancher#44110 from igomez06/v2.8-shepherd-update
Browse files Browse the repository at this point in the history
[v2.8] Updated Rancher to import the framework from the repo rancher/shepherd.
  • Loading branch information
Israel Gomez authored Feb 1, 2024
2 parents 52222ec + e5f7027 commit 68a28b0
Show file tree
Hide file tree
Showing 783 changed files with 648 additions and 39,399 deletions.
5 changes: 3 additions & 2 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -168,6 +168,7 @@ require (
github.com/antihax/optional v1.0.0
github.com/containers/image/v5 v5.25.0
github.com/rancher/rancher/pkg/apis v0.0.0-20230915232223-a9ea4ce4a5ba
github.com/rancher/shepherd v0.0.0-20240130214356-3e2c5037defb
go.qase.io/client v0.0.0-20231114201952-65195ec001fa
)

Expand Down Expand Up @@ -358,7 +359,7 @@ require (
github.com/opencontainers/image-spec v1.1.0-rc3 // indirect
github.com/opencontainers/runc v1.1.9 // indirect
github.com/peterbourgon/diskv v2.0.1+incompatible // indirect
github.com/pkg/sftp v1.13.5
github.com/pkg/sftp v1.13.5 // indirect
github.com/pmezard/go-difflib v1.0.0 // indirect
github.com/prometheus/procfs v0.10.1 // indirect
github.com/rivo/uniseg v0.4.4 // indirect
Expand All @@ -369,7 +370,7 @@ require (
github.com/russross/blackfriday/v2 v2.1.0 // indirect
github.com/shopspring/decimal v1.3.1 // indirect
github.com/spf13/cast v1.5.1 // indirect
github.com/spf13/cobra v1.7.0
github.com/spf13/cobra v1.7.0 // indirect
github.com/spf13/pflag v1.0.5 // indirect
github.com/stretchr/objx v0.5.0 // indirect
github.com/vishvananda/netns v0.0.2 // indirect
Expand Down
2 changes: 2 additions & 0 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -1038,6 +1038,8 @@ github.com/rancher/remotedialer v0.3.0 h1:y1EO8JCsgZo0RcqTUp6U8FXcBAv27R+TLnWRcp
github.com/rancher/remotedialer v0.3.0/go.mod h1:BwwztuvViX2JrLLUwDlsYt5DiyUwHLlzynRwkZLAY0Q=
github.com/rancher/rke v1.5.2-rc1 h1:8SY4nmluZFYY1+w1WdSUkku0w7fxiMZ03D4yXu17GiU=
github.com/rancher/rke v1.5.2-rc1/go.mod h1:wZaVWzW46OTuGvyxgRHXGUyJ/QP0zOkKESO9hBOwTaY=
github.com/rancher/shepherd v0.0.0-20240130214356-3e2c5037defb h1:VDAgPF6Q5yJzqoCKvuCrvwWgdqqiC5zRzrmmVYdudk0=
github.com/rancher/shepherd v0.0.0-20240130214356-3e2c5037defb/go.mod h1:WqUGpxXtHYkRV2ldhOJNDko0KZue8LBfy+gsCB7As4U=
github.com/rancher/steve v0.0.0-20231016202603-993540401906 h1:gToXZxM/5S5lze/vCpQs50PJ33QTGCOaJHzjYh6y1RE=
github.com/rancher/steve v0.0.0-20231016202603-993540401906/go.mod h1:IAeZiWgZLSGGlYOUa3qj/G6i1eKl2LFuZ/DKb9mIrzw=
github.com/rancher/system-upgrade-controller/pkg/apis v0.0.0-20210727200656-10b094e30007 h1:ru+mqGnxMmKeU0Q3XIDxkARvInDIqT1hH2amTcsjxI4=
Expand Down
22 changes: 3 additions & 19 deletions tests/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ The Rancher Test Framework provides tools for writing integrations and validatio
To run rancher integration tests you will need:
- a running instance of rancher with an accessible url
- a rancher access token for the admin user
- [golang 1.17](https://go.dev/doc/install)
- [golang 1.20](https://go.dev/doc/install)
- [k3d](https://k3d.io/v5.1.0/)

#### Validation
Expand All @@ -26,25 +26,9 @@ Integration tests - Don't require any external configuration or access to any ot

Validation tests - Require access to external services, and needs to a config file to run them.

### Extensions
## Framework

Extensions are functions that complete common operations used by tests. Extensions should not require much configuration or support multiple behaviors. Extensions should be simple enough that they can be used in many tests without needing to be tested themselves.

### Clients

Clients are used to create the resources in the tests. The advantage of the cients is they register the cleanups with sessions, making resource cleanup trivial. There are three clients; the rancher client, dynamic client, and the k3d client. The rancher client is used to create resources on a rancher instance. Given a host url, and a bearer token the rancher client communicates directly with the rancher instance. The dynamic client is used as means of communication on a downstream cluster, and used for kubernete resource management on that cluster. The k3d client is used to create a minimal k3d cluster, this is to give the integration tests the ability to test against a downstream cluster.

### Wait

Wait is used to monitor resources, and wait for specified conditions. There are multiple ways to wait for a resource. There is WatchWait that uses the watch.Interface of a resource to wait until the check function returns true. For more generic polling or waiting, the "k8s.io/apimachinery/pkg/util/wait" package can be used.

### Sessions

Sessions are used to track resources created by tests. A session allows cleanup functions to be registered while it is open. Once a session is closed the cleanup functions will be called latest to oldest. Sessions should be closed after a set of tests that use the same resources is completed. This eliminates the need for each test to create and tear down its own resources allowing for more efficient reuse of some resources. When pared with a client sessions are a powerful tool that can track and cleanup any resource a tests creates with no additional work from the developer.

### Configuration

Configuration is loaded from the yaml or json file described in `CATTLE_TEST_CONFIG`. Configuration objects are loaded from their associated key in the configuration file. Default values can also be set on configuration objects.
Shepherd is our testing framework and is located https://github.com/rancher/shepherd. For more info please visit the repo.


## How to Write Tests
Expand Down
40 changes: 0 additions & 40 deletions tests/framework/clients/corral/config.go

This file was deleted.

219 changes: 0 additions & 219 deletions tests/framework/clients/corral/corral.go

This file was deleted.

Loading

0 comments on commit 68a28b0

Please sign in to comment.