package otc import ( "fmt" "os" "testing" "github.com/stretchr/testify/suite" "github.com/xenolf/lego/platform/tester" ) type OTCSuite struct { suite.Suite Mock *DNSServerMock envTest *tester.EnvTest } func (s *OTCSuite) SetupTest() { s.Mock = NewDNSServerMock(s.T()) s.Mock.HandleAuthSuccessfully() s.envTest = tester.NewEnvTest( "OTC_DOMAIN_NAME", "OTC_USER_NAME", "OTC_PASSWORD", "OTC_PROJECT_NAME", "OTC_IDENTITY_ENDPOINT", ) } func (s *OTCSuite) TearDownTest() { s.envTest.RestoreEnv() s.Mock.ShutdownServer() } func TestTestSuite(t *testing.T) { suite.Run(t, new(OTCSuite)) } func (s *OTCSuite) createDNSProvider() (*DNSProvider, error) { config := NewDefaultConfig() config.UserName = "UserName" config.Password = "Password" config.DomainName = "DomainName" config.ProjectName = "ProjectName" config.IdentityEndpoint = fmt.Sprintf("%s/v3/auth/token", s.Mock.GetServerURL()) return NewDNSProviderConfig(config) } func (s *OTCSuite) TestLogin() { provider, err := s.createDNSProvider() s.Require().NoError(err) err = provider.loginRequest() s.Require().NoError(err) s.Equal(provider.baseURL, fmt.Sprintf("%s/v2", s.Mock.GetServerURL())) s.Equal(fakeOTCToken, provider.token) } func (s *OTCSuite) TestLoginEnv() { s.envTest.ClearEnv() s.envTest.Apply(map[string]string{ "OTC_DOMAIN_NAME": "unittest1", "OTC_USER_NAME": "unittest2", "OTC_PASSWORD": "unittest3", "OTC_PROJECT_NAME": "unittest4", "OTC_IDENTITY_ENDPOINT": "unittest5", }) provider, err := NewDNSProvider() s.Require().NoError(err) s.Equal(provider.config.DomainName, "unittest1") s.Equal(provider.config.UserName, "unittest2") s.Equal(provider.config.Password, "unittest3") s.Equal(provider.config.ProjectName, "unittest4") s.Equal(provider.config.IdentityEndpoint, "unittest5") os.Setenv("OTC_IDENTITY_ENDPOINT", "") provider, err = NewDNSProvider() s.Require().NoError(err) s.Equal(provider.config.IdentityEndpoint, "https://iam.eu-de.otc.t-systems.com:443/v3/auth/tokens") } func (s *OTCSuite) TestLoginEnvEmpty() { s.envTest.ClearEnv() _, err := NewDNSProvider() s.EqualError(err, "otc: some credentials information are missing: OTC_DOMAIN_NAME,OTC_USER_NAME,OTC_PASSWORD,OTC_PROJECT_NAME") } func (s *OTCSuite) TestDNSProvider_Present() { s.Mock.HandleListZonesSuccessfully() s.Mock.HandleListRecordsetsSuccessfully() provider, err := s.createDNSProvider() s.Require().NoError(err) err = provider.Present("example.com", "", "foobar") s.Require().NoError(err) } func (s *OTCSuite) TestDNSProvider_Present_EmptyZone() { s.Mock.HandleListZonesEmpty() s.Mock.HandleListRecordsetsSuccessfully() provider, err := s.createDNSProvider() s.Require().NoError(err) err = provider.Present("example.com", "", "foobar") s.NotNil(err) } func (s *OTCSuite) TestDNSProvider_CleanUp() { s.Mock.HandleListZonesSuccessfully() s.Mock.HandleListRecordsetsSuccessfully() s.Mock.HandleDeleteRecordsetsSuccessfully() provider, err := s.createDNSProvider() s.Require().NoError(err) err = provider.CleanUp("example.com", "", "foobar") s.Require().NoError(err) } func (s *OTCSuite) TestDNSProvider_CleanUp_EmptyRecordset() { s.Mock.HandleListZonesSuccessfully() s.Mock.HandleListRecordsetsEmpty() provider, err := s.createDNSProvider() s.Require().NoError(err) err = provider.CleanUp("example.com", "", "foobar") s.Require().Error(err) }