Documentation ¶
Index ¶
- Variables
- type ControlServer
- type Scenario
- func (s *Scenario) CountTailscale() int
- func (s *Scenario) CreateHeadscaleEnv(users map[string]int, tsOpts []tsic.Option, opts ...hsic.Option) error
- func (s *Scenario) CreatePreAuthKey(user string, reusable bool, ephemeral bool) (*v1.PreAuthKey, error)
- func (s *Scenario) CreateTailscaleNodesInUser(userStr string, requestedVersion string, count int, opts ...tsic.Option) error
- func (s *Scenario) CreateUser(user string) error
- func (s *Scenario) FindTailscaleClientByIP(ip netip.Addr) (TailscaleClient, error)
- func (s *Scenario) GetClients(user string) ([]TailscaleClient, error)
- func (s *Scenario) GetIPs(user string) ([]netip.Addr, error)
- func (s *Scenario) Headscale(opts ...hsic.Option) (ControlServer, error)
- func (s *Scenario) ListTailscaleClients(users ...string) ([]TailscaleClient, error)
- func (s *Scenario) ListTailscaleClientsFQDNs(users ...string) ([]string, error)
- func (s *Scenario) ListTailscaleClientsIPs(users ...string) ([]netip.Addr, error)
- func (s *Scenario) RunTailscaleUp(userStr, loginServer, authKey string) error
- func (s *Scenario) Shutdown()
- func (s *Scenario) Users() []string
- func (s *Scenario) WaitForTailscaleLogout() error
- func (s *Scenario) WaitForTailscaleSync() error
- func (s *Scenario) WaitForTailscaleSyncWithPeerCount(peerCount int) error
- type TailscaleClient
- type User
Constants ¶
This section is empty.
Variables ¶
var ( // AllVersions represents a list of Tailscale versions the suite // uses to test compatibility with the ControlServer. // // The list contains two special cases, "head" and "unstable" which // points to the current tip of Tailscale's main branch and the latest // released unstable version. // // The rest of the version represents Tailscale versions that can be // found in Tailscale's apt repository. AllVersions = append( enabledVersions(tailscaleVersions2021), enabledVersions(tailscaleVersions2019)..., ) // MustTestVersions is the minimum set of versions we should test. // At the moment, this is arbitrarily chosen as: // // - Two unstable (HEAD and unstable) // - Two latest versions // - Two oldest supported version. MustTestVersions = append( AllVersions[0:4], AllVersions[len(AllVersions)-2:]..., ) )
Functions ¶
This section is empty.
Types ¶
type ControlServer ¶
type ControlServer interface { Shutdown() error SaveLog(string) error SaveProfile(string) error Execute(command []string) (string, error) WriteFile(path string, content []byte) error ConnectToNetwork(network *dockertest.Network) error GetHealthEndpoint() string GetEndpoint() string WaitForRunning() error CreateUser(user string) error CreateAuthKey(user string, reusable bool, ephemeral bool) (*v1.PreAuthKey, error) ListNodesInUser(user string) ([]*v1.Node, error) GetCert() []byte GetHostname() string GetIP() string }
type Scenario ¶
type Scenario struct {
// contains filtered or unexported fields
}
Scenario is a representation of an environment with one ControlServer and one or more User's and its associated TailscaleClients. A Scenario is intended to simplify setting up a new testcase for testing a ControlServer with TailscaleClients. TODO(kradalby): make control server configurable, test correctness with Tailscale SaaS.
func NewScenario ¶
NewScenario creates a test Scenario which can be used to bootstraps a ControlServer with a set of Users and TailscaleClients.
func (*Scenario) CountTailscale ¶
CountTailscale returns the total number of TailscaleClients in a Scenario. This is the sum of Users x TailscaleClients.
func (*Scenario) CreateHeadscaleEnv ¶
func (s *Scenario) CreateHeadscaleEnv( users map[string]int, tsOpts []tsic.Option, opts ...hsic.Option, ) error
CreateHeadscaleEnv is a convenient method returning a complete Headcale test environment with nodes of all versions, joined to the server with X users.
func (*Scenario) CreatePreAuthKey ¶
func (s *Scenario) CreatePreAuthKey( user string, reusable bool, ephemeral bool, ) (*v1.PreAuthKey, error)
CreatePreAuthKey creates a "pre authentorised key" to be created in the Headscale instance on behalf of the Scenario.
func (*Scenario) CreateTailscaleNodesInUser ¶
func (s *Scenario) CreateTailscaleNodesInUser( userStr string, requestedVersion string, count int, opts ...tsic.Option, ) error
CreateTailscaleNodesInUser creates and adds a new TailscaleClient to a User in the Scenario.
func (*Scenario) CreateUser ¶
CreateUser creates a User to be created in the Headscale instance on behalf of the Scenario.
func (*Scenario) FindTailscaleClientByIP ¶
func (s *Scenario) FindTailscaleClientByIP(ip netip.Addr) (TailscaleClient, error)
FindTailscaleClientByIP returns a TailscaleClient associated with an IP address if it exists.
func (*Scenario) GetClients ¶
func (s *Scenario) GetClients(user string) ([]TailscaleClient, error)
GetClients returns all TailscaleClients associated with a User in a Scenario.
func (*Scenario) GetIPs ¶
GetIPs returns all netip.Addr of TailscaleClients associated with a User in a Scenario.
func (*Scenario) Headscale ¶
func (s *Scenario) Headscale(opts ...hsic.Option) (ControlServer, error)
Headscale returns a ControlServer instance based on hsic (HeadscaleInContainer) If the Scenario already has an instance, the pointer to the running container will be return, otherwise a new instance will be created. TODO(kradalby): make port and headscale configurable, multiple instances support?
func (*Scenario) ListTailscaleClients ¶
func (s *Scenario) ListTailscaleClients(users ...string) ([]TailscaleClient, error)
ListTailscaleClients returns a list of TailscaleClients given the Users passed as parameters.
func (*Scenario) ListTailscaleClientsFQDNs ¶
ListTailscaleClientsFQDNs returns a list of FQDN based on Users passed as parameters.
func (*Scenario) ListTailscaleClientsIPs ¶
ListTailscaleClientsIPs returns a list of netip.Addr based on Users passed as parameters.
func (*Scenario) RunTailscaleUp ¶
RunTailscaleUp will log in all of the TailscaleClients associated with a User to the given ControlServer (by URL).
func (*Scenario) Shutdown ¶
func (s *Scenario) Shutdown()
Shutdown shuts down and cleans up all the containers (ControlServer, TailscaleClient) and networks associated with it. In addition, it will save the logs of the ControlServer to `/tmp/control` in the environment running the tests.
func (*Scenario) WaitForTailscaleLogout ¶
WaitForTailscaleLogout blocks execution until all TailscaleClients have logged out of the ControlServer.
func (*Scenario) WaitForTailscaleSync ¶
WaitForTailscaleSync blocks execution until all the TailscaleClient reports to have all other TailscaleClients present in their netmap.NetworkMap.
func (*Scenario) WaitForTailscaleSyncWithPeerCount ¶
WaitForTailscaleSyncWithPeerCount blocks execution until all the TailscaleClient reports to have all other TailscaleClients present in their netmap.NetworkMap.
type TailscaleClient ¶
type TailscaleClient interface { Hostname() string Shutdown() error Version() string Execute( command []string, options ...dockertestutil.ExecuteCommandOption, ) (string, string, error) Login(loginServer, authKey string) error LoginWithURL(loginServer string) (*url.URL, error) Logout() error Up() error Down() error IPs() ([]netip.Addr, error) FQDN() (string, error) Status(...bool) (*ipnstate.Status, error) Netmap() (*netmap.NetworkMap, error) Netcheck() (*netcheck.Report, error) WaitForNeedsLogin() error WaitForRunning() error WaitForPeers(expected int) error Ping(hostnameOrIP string, opts ...tsic.PingOption) error Curl(url string, opts ...tsic.CurlOption) (string, error) ID() string ReadFile(path string) ([]byte, error) // FailingPeersAsString returns a formatted-ish multi-line-string of peers in the client // and a bool indicating if the clients online count and peer count is equal. FailingPeersAsString() (string, bool, error) }
nolint
type User ¶
type User struct { Clients map[string]TailscaleClient // contains filtered or unexported fields }
User represents a User in the ControlServer and a map of TailscaleClient's associated with the User.