/* * MinIO Cloud Storage, (C) 2019 MinIO, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package lifecycle import ( "encoding/xml" "fmt" "testing" ) // TestUnsupportedRules checks if Rule xml with unsuported tags return // appropriate errors on parsing func TestUnsupportedRules(t *testing.T) { // NoncurrentVersionTransition, and Transition tags aren't supported unsupportedTestCases := []struct { inputXML string expectedErr error }{ { // Rule with unsupported NoncurrentVersionTransition inputXML: ` `, expectedErr: errNoncurrentVersionTransitionUnsupported, }, { // Rule with unsupported Transition action inputXML: ` `, expectedErr: errTransitionUnsupported, }, } for i, tc := range unsupportedTestCases { t.Run(fmt.Sprintf("Test %d", i+1), func(t *testing.T) { var rule Rule err := xml.Unmarshal([]byte(tc.inputXML), &rule) if err != tc.expectedErr { t.Fatalf("%d: Expected %v but got %v", i+1, tc.expectedErr, err) } }) } } // TestInvalidRules checks if Rule xml with invalid elements returns // appropriate errors on validation func TestInvalidRules(t *testing.T) { invalidTestCases := []struct { inputXML string expectedErr error }{ { // Rule without expiration action inputXML: ` rule without expiration Enabled `, expectedErr: errLifecycleInvalidExpiration, }, { // Rule with ID longer than 255 characters inputXML: ` babababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababababab `, expectedErr: errInvalidRuleID, }, { // Rule with empty ID inputXML: ` 365 Enabled `, expectedErr: nil, }, { // Rule with empty status inputXML: ` rule with empty status `, expectedErr: errEmptyRuleStatus, }, { // Rule with invalid status inputXML: ` rule with invalid status OK `, expectedErr: errInvalidRuleStatus, }, } for i, tc := range invalidTestCases { t.Run(fmt.Sprintf("Test %d", i+1), func(t *testing.T) { var rule Rule err := xml.Unmarshal([]byte(tc.inputXML), &rule) if err != nil { t.Fatal(err) } if err := rule.Validate(); err != tc.expectedErr { t.Fatalf("%d: Expected %v but got %v", i+1, tc.expectedErr, err) } }) } }