func (s *remoteSuite) TestIDLocal(c *gc.C) { remote := lxdclient.Remote{ Name: "my-remote", Host: "", Cert: s.Cert, } id := remote.ID() c.Check(id, gc.Equals, "local") }
func (s *remoteSuite) TestValidateLocalWithCert(c *gc.C) { remote := lxdclient.Remote{ Name: "my-local", Host: "", Cert: &lxdclient.Cert{}, } err := remote.Validate() c.Check(err, jc.Satisfies, errors.IsNotValid) }
func (s *remoteSuite) TestIDOkay(c *gc.C) { remote := lxdclient.Remote{ Name: "my-remote", Host: "some-host", Cert: s.Cert, } id := remote.ID() c.Check(id, gc.Equals, "my-remote") }
func (s *remoteSuite) TestValidateLocalMissingName(c *gc.C) { remote := lxdclient.Remote{ Name: "", Host: "", Cert: nil, } err := remote.Validate() c.Check(err, jc.Satisfies, errors.IsNotValid) }
func (s *remoteSuite) TestValidateLocalOkay(c *gc.C) { remote := lxdclient.Remote{ Name: "my-local", Host: "", Cert: nil, } err := remote.Validate() c.Check(err, jc.ErrorIsNil) }
func (s *remoteSuite) TestValidateBadCert(c *gc.C) { remote := lxdclient.Remote{ Name: "my-remote", Host: "some-host", Cert: &lxdclient.Cert{}, } err := remote.Validate() c.Check(err, jc.Satisfies, errors.IsNotValid) }
func (s *remoteSuite) TestValidateOkay(c *gc.C) { remote := lxdclient.Remote{ Name: "my-remote", Host: "some-host", Cert: s.Cert, } err := remote.Validate() c.Check(err, jc.ErrorIsNil) }
func (s *remoteSuite) TestWithDefaultsMissingName(c *gc.C) { remote := lxdclient.Remote{ Name: "", Host: "some-host", Cert: s.Cert, } updated, err := remote.WithDefaults() c.Assert(err, jc.ErrorIsNil) c.Check(updated, jc.DeepEquals, remote) // Name is not updated. }
func (s *remoteSuite) TestUsingTCPNoop(c *gc.C) { remote := lxdclient.Remote{ Name: "my-remote", Host: "some-host", Cert: s.Cert, } nonlocal, err := remote.UsingTCP() c.Assert(err, jc.ErrorIsNil) c.Check(nonlocal, jc.DeepEquals, remote) }
func (s *remoteSuite) TestWithDefaultsZeroValue(c *gc.C) { var remote lxdclient.Remote updated, err := remote.WithDefaults() c.Assert(err, jc.ErrorIsNil) err = updated.Validate() c.Check(err, jc.ErrorIsNil) c.Check(updated, jc.DeepEquals, lxdclient.Remote{ Name: "local", Host: "", Cert: nil, }) }
func (s *remoteSuite) TestWithDefaultsNoop(c *gc.C) { remote := lxdclient.Remote{ Name: "my-remote", Host: "some-host", Cert: s.Cert, } updated, err := remote.WithDefaults() c.Assert(err, jc.ErrorIsNil) err = updated.Validate() c.Check(err, jc.ErrorIsNil) c.Check(updated, jc.DeepEquals, remote) }
func (s *remoteSuite) TestWithDefaultsLocalNoop(c *gc.C) { remote := lxdclient.Remote{ Name: "my-local", Host: "", Cert: nil, } updated, err := remote.WithDefaults() c.Assert(err, jc.ErrorIsNil) err = updated.Validate() c.Check(err, jc.ErrorIsNil) c.Check(updated, jc.DeepEquals, lxdclient.Remote{ Name: "my-local", Host: "", Cert: nil, }) }
func (s *remoteFunctionalSuite) TestUsingTCP(c *gc.C) { if _, err := net.InterfaceByName(lxc.DefaultLxcBridge); err != nil { c.Skip("network bridge interface not found") } remote := lxdclient.Remote{ Name: "my-remote", Host: "", Cert: nil, } nonlocal, err := remote.UsingTCP() c.Assert(err, jc.ErrorIsNil) checkValidRemote(c, &nonlocal) c.Check(nonlocal, jc.DeepEquals, lxdclient.Remote{ Name: "my-remote", Host: nonlocal.Host, Cert: nonlocal.Cert, }) }
// TODO(ericsnow) Move this test to a functional suite. func (s *remoteSuite) TestWithDefaultsMissingCert(c *gc.C) { remote := lxdclient.Remote{ Name: "my-remote", Host: "some-host", Cert: nil, } err := remote.Validate() c.Assert(err, gc.NotNil) // Make sure the original is invalid. updated, err := remote.WithDefaults() c.Assert(err, jc.ErrorIsNil) err = updated.Validate() c.Check(err, jc.ErrorIsNil) updated.Cert = nil // Validate ensured that the cert was okay. c.Check(updated, jc.DeepEquals, lxdclient.Remote{ Name: "my-remote", Host: "some-host", Cert: nil, }) }
// clientConfig builds a LXD Config based on the env config and returns it. func (c *environConfig) clientConfig() (lxdclient.Config, error) { remote := lxdclient.Remote{ Name: "juju-remote", Host: c.remoteURL(), } if c.clientCert() != "" { certPEM := []byte(c.clientCert()) keyPEM := []byte(c.clientKey()) cert := lxdclient.NewCert(certPEM, keyPEM) cert.Name = fmt.Sprintf("juju cert for env %q", c.Name()) remote.Cert = &cert } cfg := lxdclient.Config{ Namespace: c.namespace(), Dirname: lxdclient.ConfigPath("juju-" + c.namespace()), Remote: remote, } cfg, err := cfg.WithDefaults() if err != nil { return cfg, errors.Trace(err) } return cfg, nil }
func (s *remoteSuite) TestValidateZeroValue(c *gc.C) { var remote lxdclient.Remote err := remote.Validate() c.Check(err, jc.Satisfies, errors.IsNotValid) }