From b2007f9241f37a8177d0f5d592efe57e821e0a2e Mon Sep 17 00:00:00 2001 From: David Elie-Dit-Cosaque <86730676+edcdavid@users.noreply.github.com> Date: Wed, 12 Jul 2023 11:41:16 -0500 Subject: [PATCH] Adding a claim format version (#94) --- pkg/claim/schema.go | 1210 +++++++++-------- .../claim-invalid-additional-property.json | 3 +- .../testdata/claim-invalid-bool-results.json | 3 +- .../testdata/claim-invalid-junit-payload.json | 3 +- .../claim-invalid-non-result-result.json | 3 +- pkg/claim/testdata/claim-valid.json | 3 +- schemas/claim.schema.json | 7 +- 7 files changed, 634 insertions(+), 598 deletions(-) diff --git a/pkg/claim/schema.go b/pkg/claim/schema.go index 8b5eabc..badb903 100644 --- a/pkg/claim/schema.go +++ b/pkg/claim/schema.go @@ -11,7 +11,7 @@ // Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. // -// Code generated by `test-network-function-claim/cmd/generate/generate.go` on: 2023-02-22 11:19:10.892144 -0600 CST m=+0.002102455 +// Code generated by `test-network-function-claim/cmd/generate/generate.go` on: 2023-07-10 18:08:54.851201899 -0500 CDT m=+0.000974451 // // `https://github.com/a-h/generate` provides a generic set of interfaces to convert JSON schema into // workable GoLang struct implementations. However, the code generator is limited and does not allow @@ -28,193 +28,196 @@ package claim import ( - "errors" - "encoding/json" - "fmt" - "bytes" + "bytes" + "encoding/json" + "errors" + "fmt" ) -// Claim +// Claim type Claim struct { - // Tests within test-network-function often require configuration. For example, the generic test suite requires listing all CNF containers. This information is used to derive per-container IP address information, which is then used as input to the connectivity test suite. Test suites within test-network-function may use multiple configurations, but each with a unique name. - Configurations map[string]interface{} `json:"configurations"` - Metadata *Metadata `json:"metadata"` + // Tests within test-network-function often require configuration. For example, the generic test suite requires listing all CNF containers. This information is used to derive per-container IP address information, which is then used as input to the connectivity test suite. Test suites within test-network-function may use multiple configurations, but each with a unique name. + Configurations map[string]interface{} `json:"configurations"` + Metadata *Metadata `json:"metadata"` - // An OpenShift cluster is composed of an arbitrary number of Nodes used for platform and application services. Since a claim must be reproducible, a variety of per-Node information must be collected and stored in the claim. Node names are unique within a given OpenShift cluster. - Nodes map[string]interface{} `json:"nodes"` + // An OpenShift cluster is composed of an arbitrary number of Nodes used for platform and application services. Since a claim must be reproducible, a variety of per-Node information must be collected and stored in the claim. Node names are unique within a given OpenShift cluster. + Nodes map[string]interface{} `json:"nodes"` - // The test-network-function test results. Results are a JSON representation of the JUnit output. - RawResults map[string]interface{} `json:"rawResults"` + // The test-network-function test results. Results are a JSON representation of the JUnit output. + RawResults map[string]interface{} `json:"rawResults"` - // The results for each unique test case. - Results map[string]interface{} `json:"results,omitempty"` - Versions *Versions `json:"versions"` + // The results for each unique test case. + Results map[string]interface{} `json:"results,omitempty"` + Versions *Versions `json:"versions"` } // Identifier identifier is a per testcase unique identifier. type Identifier struct { - // id stores a unique id for the testcase. - Id string `json:"id"` + // id stores a unique id for the testcase. + Id string `json:"id"` - // suite stores the test suite name for the testcase. - Suite string `json:"suite"` + // suite stores the test suite name for the testcase. + Suite string `json:"suite"` - // tags stores the different tags applied to a test. - Tags string `json:"tags,omitempty"` + // tags stores the different tags applied to a test. + Tags string `json:"tags,omitempty"` } -// Metadata +// Metadata type Metadata struct { - // The UTC end time of a claim evaluation. This is recorded when the test-network-function test suite completes. - EndTime string `json:"endTime"` + // The UTC end time of a claim evaluation. This is recorded when the test-network-function test suite completes. + EndTime string `json:"endTime"` - // The UTC start time of a claim evaluation. This is recorded when the test-network-function test suite is invoked. - StartTime string `json:"startTime"` + // The UTC start time of a claim evaluation. This is recorded when the test-network-function test suite is invoked. + StartTime string `json:"startTime"` } // Result result is the result of running a testcase. type Result struct { - // Ginkgo writer output during the test run. - CapturedTestOutput string `json:"CapturedTestOutput"` + // Ginkgo writer output during the test run. + CapturedTestOutput string `json:"CapturedTestOutput"` - // The duration of the test in nanoseconds. - Duration int `json:"duration"` + // The duration of the test in nanoseconds. + Duration int `json:"duration"` - // The end time of the test. - EndTime string `json:"endTime,omitempty"` + // The end time of the test. + EndTime string `json:"endTime,omitempty"` - // The content of the line where the failure happened - FailureLineContent string `json:"failureLineContent"` + // The content of the line where the failure happened + FailureLineContent string `json:"failureLineContent"` - // The Filename and line number where the failure happened - FailureLocation string `json:"failureLocation"` + // The Filename and line number where the failure happened + FailureLocation string `json:"failureLocation"` - // Describes the test failure in detail. - FailureReason string `json:"failureReason"` + // Describes the test failure in detail. + FailureReason string `json:"failureReason"` - // The start time of the test. - StartTime string `json:"startTime"` + // The start time of the test. + StartTime string `json:"startTime"` - // The test result state: INVALID SPEC STATE, pending,skipped,passed,failed,aborted,panicked,interrupted - State string `json:"state"` + // The test result state: INVALID SPEC STATE, pending,skipped,passed,failed,aborted,panicked,interrupted + State string `json:"state"` - // The test identifier - TestID *Identifier `json:"testID,omitempty"` + // The test identifier + TestID *Identifier `json:"testID,omitempty"` - // The JUnit test text. - TestText string `json:"testText"` + // The JUnit test text. + TestText string `json:"testText"` } // Root A test-network-function claim is an attestation of the tests performed, the results and the various configurations. Since a claim must be reproducible, it also includes an overview of the systems under test and their physical configurations. type Root struct { - Claim *Claim `json:"claim"` + Claim *Claim `json:"claim"` } -// Versions +// Versions type Versions struct { - // The Kubernetes release version. - K8s string `json:"k8s,omitempty"` + // The claim file format version. + ClaimFormat string `json:"claimFormat"` - // The oc client release version. - OcClient string `json:"ocClient,omitempty"` + // The Kubernetes release version. + K8s string `json:"k8s,omitempty"` - // OCP cluster release version. - Ocp string `json:"ocp,omitempty"` + // The oc client release version. + OcClient string `json:"ocClient,omitempty"` - // The test-network-function (tnf) release version. - Tnf string `json:"tnf"` + // OCP cluster release version. + Ocp string `json:"ocp,omitempty"` - // The test-network-function (tnf) Git Commit. - TnfGitCommit string `json:"tnfGitCommit,omitempty"` + // The test-network-function (tnf) release version. + Tnf string `json:"tnf"` + + // The test-network-function (tnf) Git Commit. + TnfGitCommit string `json:"tnfGitCommit,omitempty"` } func (strct *Claim) MarshalJSON() ([]byte, error) { buf := bytes.NewBuffer(make([]byte, 0)) buf.WriteString("{") - comma := false - // "Configurations" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "configurations" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"configurations\": ") + comma := false + // "Configurations" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "configurations" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"configurations\": ") if tmp, err := json.Marshal(strct.Configurations); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "Metadata" field is required - if strct.Metadata == nil { - return nil, errors.New("metadata is a required field") - } - // Marshal the "metadata" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"metadata\": ") + // "Metadata" field is required + if strct.Metadata == nil { + return nil, errors.New("metadata is a required field") + } + // Marshal the "metadata" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"metadata\": ") if tmp, err := json.Marshal(strct.Metadata); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "Nodes" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "nodes" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"nodes\": ") + // "Nodes" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "nodes" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"nodes\": ") if tmp, err := json.Marshal(strct.Nodes); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "RawResults" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "rawResults" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"rawResults\": ") + // "RawResults" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "rawResults" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"rawResults\": ") if tmp, err := json.Marshal(strct.RawResults); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // Marshal the "results" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"results\": ") + // Marshal the "results" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"results\": ") if tmp, err := json.Marshal(strct.Results); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "Versions" field is required - if strct.Versions == nil { - return nil, errors.New("versions is a required field") - } - // Marshal the "versions" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"versions\": ") + // "Versions" field is required + if strct.Versions == nil { + return nil, errors.New("versions is a required field") + } + // Marshal the "versions" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"versions\": ") if tmp, err := json.Marshal(strct.Versions); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true @@ -224,113 +227,113 @@ func (strct *Claim) MarshalJSON() ([]byte, error) { } func (strct *Claim) UnmarshalJSON(b []byte) error { - configurationsReceived := false - metadataReceived := false - nodesReceived := false - rawResultsReceived := false - versionsReceived := false - var jsonMap map[string]json.RawMessage - if err := json.Unmarshal(b, &jsonMap); err != nil { - return err - } - // parse all the defined properties - for k, v := range jsonMap { - switch k { - case "configurations": - if err := json.Unmarshal([]byte(v), &strct.Configurations); err != nil { - return err - } - configurationsReceived = true - case "metadata": - if err := json.Unmarshal([]byte(v), &strct.Metadata); err != nil { - return err - } - metadataReceived = true - case "nodes": - if err := json.Unmarshal([]byte(v), &strct.Nodes); err != nil { - return err - } - nodesReceived = true - case "rawResults": - if err := json.Unmarshal([]byte(v), &strct.RawResults); err != nil { - return err - } - rawResultsReceived = true - case "results": - if err := json.Unmarshal([]byte(v), &strct.Results); err != nil { - return err - } - case "versions": - if err := json.Unmarshal([]byte(v), &strct.Versions); err != nil { - return err - } - versionsReceived = true - default: - return fmt.Errorf("additional property not allowed: \"" + k + "\"") - } - } - // check if configurations (a required property) was received - if !configurationsReceived { - return errors.New("\"configurations\" is required but was not present") - } - // check if metadata (a required property) was received - if !metadataReceived { - return errors.New("\"metadata\" is required but was not present") - } - // check if nodes (a required property) was received - if !nodesReceived { - return errors.New("\"nodes\" is required but was not present") - } - // check if rawResults (a required property) was received - if !rawResultsReceived { - return errors.New("\"rawResults\" is required but was not present") - } - // check if versions (a required property) was received - if !versionsReceived { - return errors.New("\"versions\" is required but was not present") - } - return nil + configurationsReceived := false + metadataReceived := false + nodesReceived := false + rawResultsReceived := false + versionsReceived := false + var jsonMap map[string]json.RawMessage + if err := json.Unmarshal(b, &jsonMap); err != nil { + return err + } + // parse all the defined properties + for k, v := range jsonMap { + switch k { + case "configurations": + if err := json.Unmarshal([]byte(v), &strct.Configurations); err != nil { + return err + } + configurationsReceived = true + case "metadata": + if err := json.Unmarshal([]byte(v), &strct.Metadata); err != nil { + return err + } + metadataReceived = true + case "nodes": + if err := json.Unmarshal([]byte(v), &strct.Nodes); err != nil { + return err + } + nodesReceived = true + case "rawResults": + if err := json.Unmarshal([]byte(v), &strct.RawResults); err != nil { + return err + } + rawResultsReceived = true + case "results": + if err := json.Unmarshal([]byte(v), &strct.Results); err != nil { + return err + } + case "versions": + if err := json.Unmarshal([]byte(v), &strct.Versions); err != nil { + return err + } + versionsReceived = true + default: + return fmt.Errorf("additional property not allowed: \"" + k + "\"") + } + } + // check if configurations (a required property) was received + if !configurationsReceived { + return errors.New("\"configurations\" is required but was not present") + } + // check if metadata (a required property) was received + if !metadataReceived { + return errors.New("\"metadata\" is required but was not present") + } + // check if nodes (a required property) was received + if !nodesReceived { + return errors.New("\"nodes\" is required but was not present") + } + // check if rawResults (a required property) was received + if !rawResultsReceived { + return errors.New("\"rawResults\" is required but was not present") + } + // check if versions (a required property) was received + if !versionsReceived { + return errors.New("\"versions\" is required but was not present") + } + return nil } func (strct *Identifier) MarshalJSON() ([]byte, error) { buf := bytes.NewBuffer(make([]byte, 0)) buf.WriteString("{") - comma := false - // "Id" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "id" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"id\": ") + comma := false + // "Id" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "id" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"id\": ") if tmp, err := json.Marshal(strct.Id); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "Suite" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "suite" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"suite\": ") + // "Suite" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "suite" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"suite\": ") if tmp, err := json.Marshal(strct.Suite); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // Marshal the "tags" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"tags\": ") + // Marshal the "tags" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"tags\": ") if tmp, err := json.Marshal(strct.Tags); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true @@ -340,72 +343,72 @@ func (strct *Identifier) MarshalJSON() ([]byte, error) { } func (strct *Identifier) UnmarshalJSON(b []byte) error { - idReceived := false - suiteReceived := false - var jsonMap map[string]json.RawMessage - if err := json.Unmarshal(b, &jsonMap); err != nil { - return err - } - // parse all the defined properties - for k, v := range jsonMap { - switch k { - case "id": - if err := json.Unmarshal([]byte(v), &strct.Id); err != nil { - return err - } - idReceived = true - case "suite": - if err := json.Unmarshal([]byte(v), &strct.Suite); err != nil { - return err - } - suiteReceived = true - case "tags": - if err := json.Unmarshal([]byte(v), &strct.Tags); err != nil { - return err - } - default: - return fmt.Errorf("additional property not allowed: \"" + k + "\"") - } - } - // check if id (a required property) was received - if !idReceived { - return errors.New("\"id\" is required but was not present") - } - // check if suite (a required property) was received - if !suiteReceived { - return errors.New("\"suite\" is required but was not present") - } - return nil + idReceived := false + suiteReceived := false + var jsonMap map[string]json.RawMessage + if err := json.Unmarshal(b, &jsonMap); err != nil { + return err + } + // parse all the defined properties + for k, v := range jsonMap { + switch k { + case "id": + if err := json.Unmarshal([]byte(v), &strct.Id); err != nil { + return err + } + idReceived = true + case "suite": + if err := json.Unmarshal([]byte(v), &strct.Suite); err != nil { + return err + } + suiteReceived = true + case "tags": + if err := json.Unmarshal([]byte(v), &strct.Tags); err != nil { + return err + } + default: + return fmt.Errorf("additional property not allowed: \"" + k + "\"") + } + } + // check if id (a required property) was received + if !idReceived { + return errors.New("\"id\" is required but was not present") + } + // check if suite (a required property) was received + if !suiteReceived { + return errors.New("\"suite\" is required but was not present") + } + return nil } func (strct *Metadata) MarshalJSON() ([]byte, error) { buf := bytes.NewBuffer(make([]byte, 0)) buf.WriteString("{") - comma := false - // "EndTime" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "endTime" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"endTime\": ") + comma := false + // "EndTime" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "endTime" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"endTime\": ") if tmp, err := json.Marshal(strct.EndTime); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "StartTime" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "startTime" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"startTime\": ") + // "StartTime" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "startTime" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"startTime\": ") if tmp, err := json.Marshal(strct.StartTime); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true @@ -415,168 +418,168 @@ func (strct *Metadata) MarshalJSON() ([]byte, error) { } func (strct *Metadata) UnmarshalJSON(b []byte) error { - endTimeReceived := false - startTimeReceived := false - var jsonMap map[string]json.RawMessage - if err := json.Unmarshal(b, &jsonMap); err != nil { - return err - } - // parse all the defined properties - for k, v := range jsonMap { - switch k { - case "endTime": - if err := json.Unmarshal([]byte(v), &strct.EndTime); err != nil { - return err - } - endTimeReceived = true - case "startTime": - if err := json.Unmarshal([]byte(v), &strct.StartTime); err != nil { - return err - } - startTimeReceived = true - default: - return fmt.Errorf("additional property not allowed: \"" + k + "\"") - } - } - // check if endTime (a required property) was received - if !endTimeReceived { - return errors.New("\"endTime\" is required but was not present") - } - // check if startTime (a required property) was received - if !startTimeReceived { - return errors.New("\"startTime\" is required but was not present") - } - return nil + endTimeReceived := false + startTimeReceived := false + var jsonMap map[string]json.RawMessage + if err := json.Unmarshal(b, &jsonMap); err != nil { + return err + } + // parse all the defined properties + for k, v := range jsonMap { + switch k { + case "endTime": + if err := json.Unmarshal([]byte(v), &strct.EndTime); err != nil { + return err + } + endTimeReceived = true + case "startTime": + if err := json.Unmarshal([]byte(v), &strct.StartTime); err != nil { + return err + } + startTimeReceived = true + default: + return fmt.Errorf("additional property not allowed: \"" + k + "\"") + } + } + // check if endTime (a required property) was received + if !endTimeReceived { + return errors.New("\"endTime\" is required but was not present") + } + // check if startTime (a required property) was received + if !startTimeReceived { + return errors.New("\"startTime\" is required but was not present") + } + return nil } func (strct *Result) MarshalJSON() ([]byte, error) { buf := bytes.NewBuffer(make([]byte, 0)) buf.WriteString("{") - comma := false - // "CapturedTestOutput" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "CapturedTestOutput" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"CapturedTestOutput\": ") + comma := false + // "CapturedTestOutput" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "CapturedTestOutput" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"CapturedTestOutput\": ") if tmp, err := json.Marshal(strct.CapturedTestOutput); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "Duration" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "duration" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"duration\": ") + // "Duration" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "duration" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"duration\": ") if tmp, err := json.Marshal(strct.Duration); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // Marshal the "endTime" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"endTime\": ") + // Marshal the "endTime" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"endTime\": ") if tmp, err := json.Marshal(strct.EndTime); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "FailureLineContent" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "failureLineContent" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"failureLineContent\": ") + // "FailureLineContent" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "failureLineContent" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"failureLineContent\": ") if tmp, err := json.Marshal(strct.FailureLineContent); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "FailureLocation" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "failureLocation" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"failureLocation\": ") + // "FailureLocation" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "failureLocation" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"failureLocation\": ") if tmp, err := json.Marshal(strct.FailureLocation); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "FailureReason" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "failureReason" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"failureReason\": ") + // "FailureReason" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "failureReason" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"failureReason\": ") if tmp, err := json.Marshal(strct.FailureReason); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "StartTime" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "startTime" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"startTime\": ") + // "StartTime" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "startTime" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"startTime\": ") if tmp, err := json.Marshal(strct.StartTime); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "State" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "state" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"state\": ") + // "State" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "state" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"state\": ") if tmp, err := json.Marshal(strct.State); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // Marshal the "testID" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"testID\": ") + // Marshal the "testID" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"testID\": ") if tmp, err := json.Marshal(strct.TestID); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "TestText" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "testText" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"testText\": ") + // "TestText" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "testText" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"testText\": ") if tmp, err := json.Marshal(strct.TestText); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true @@ -586,125 +589,125 @@ func (strct *Result) MarshalJSON() ([]byte, error) { } func (strct *Result) UnmarshalJSON(b []byte) error { - CapturedTestOutputReceived := false - durationReceived := false - failureLineContentReceived := false - failureLocationReceived := false - failureReasonReceived := false - startTimeReceived := false - stateReceived := false - testTextReceived := false - var jsonMap map[string]json.RawMessage - if err := json.Unmarshal(b, &jsonMap); err != nil { - return err - } - // parse all the defined properties - for k, v := range jsonMap { - switch k { - case "CapturedTestOutput": - if err := json.Unmarshal([]byte(v), &strct.CapturedTestOutput); err != nil { - return err - } - CapturedTestOutputReceived = true - case "duration": - if err := json.Unmarshal([]byte(v), &strct.Duration); err != nil { - return err - } - durationReceived = true - case "endTime": - if err := json.Unmarshal([]byte(v), &strct.EndTime); err != nil { - return err - } - case "failureLineContent": - if err := json.Unmarshal([]byte(v), &strct.FailureLineContent); err != nil { - return err - } - failureLineContentReceived = true - case "failureLocation": - if err := json.Unmarshal([]byte(v), &strct.FailureLocation); err != nil { - return err - } - failureLocationReceived = true - case "failureReason": - if err := json.Unmarshal([]byte(v), &strct.FailureReason); err != nil { - return err - } - failureReasonReceived = true - case "startTime": - if err := json.Unmarshal([]byte(v), &strct.StartTime); err != nil { - return err - } - startTimeReceived = true - case "state": - if err := json.Unmarshal([]byte(v), &strct.State); err != nil { - return err - } - stateReceived = true - case "testID": - if err := json.Unmarshal([]byte(v), &strct.TestID); err != nil { - return err - } - case "testText": - if err := json.Unmarshal([]byte(v), &strct.TestText); err != nil { - return err - } - testTextReceived = true - default: - return fmt.Errorf("additional property not allowed: \"" + k + "\"") - } - } - // check if CapturedTestOutput (a required property) was received - if !CapturedTestOutputReceived { - return errors.New("\"CapturedTestOutput\" is required but was not present") - } - // check if duration (a required property) was received - if !durationReceived { - return errors.New("\"duration\" is required but was not present") - } - // check if failureLineContent (a required property) was received - if !failureLineContentReceived { - return errors.New("\"failureLineContent\" is required but was not present") - } - // check if failureLocation (a required property) was received - if !failureLocationReceived { - return errors.New("\"failureLocation\" is required but was not present") - } - // check if failureReason (a required property) was received - if !failureReasonReceived { - return errors.New("\"failureReason\" is required but was not present") - } - // check if startTime (a required property) was received - if !startTimeReceived { - return errors.New("\"startTime\" is required but was not present") - } - // check if state (a required property) was received - if !stateReceived { - return errors.New("\"state\" is required but was not present") - } - // check if testText (a required property) was received - if !testTextReceived { - return errors.New("\"testText\" is required but was not present") - } - return nil + CapturedTestOutputReceived := false + durationReceived := false + failureLineContentReceived := false + failureLocationReceived := false + failureReasonReceived := false + startTimeReceived := false + stateReceived := false + testTextReceived := false + var jsonMap map[string]json.RawMessage + if err := json.Unmarshal(b, &jsonMap); err != nil { + return err + } + // parse all the defined properties + for k, v := range jsonMap { + switch k { + case "CapturedTestOutput": + if err := json.Unmarshal([]byte(v), &strct.CapturedTestOutput); err != nil { + return err + } + CapturedTestOutputReceived = true + case "duration": + if err := json.Unmarshal([]byte(v), &strct.Duration); err != nil { + return err + } + durationReceived = true + case "endTime": + if err := json.Unmarshal([]byte(v), &strct.EndTime); err != nil { + return err + } + case "failureLineContent": + if err := json.Unmarshal([]byte(v), &strct.FailureLineContent); err != nil { + return err + } + failureLineContentReceived = true + case "failureLocation": + if err := json.Unmarshal([]byte(v), &strct.FailureLocation); err != nil { + return err + } + failureLocationReceived = true + case "failureReason": + if err := json.Unmarshal([]byte(v), &strct.FailureReason); err != nil { + return err + } + failureReasonReceived = true + case "startTime": + if err := json.Unmarshal([]byte(v), &strct.StartTime); err != nil { + return err + } + startTimeReceived = true + case "state": + if err := json.Unmarshal([]byte(v), &strct.State); err != nil { + return err + } + stateReceived = true + case "testID": + if err := json.Unmarshal([]byte(v), &strct.TestID); err != nil { + return err + } + case "testText": + if err := json.Unmarshal([]byte(v), &strct.TestText); err != nil { + return err + } + testTextReceived = true + default: + return fmt.Errorf("additional property not allowed: \"" + k + "\"") + } + } + // check if CapturedTestOutput (a required property) was received + if !CapturedTestOutputReceived { + return errors.New("\"CapturedTestOutput\" is required but was not present") + } + // check if duration (a required property) was received + if !durationReceived { + return errors.New("\"duration\" is required but was not present") + } + // check if failureLineContent (a required property) was received + if !failureLineContentReceived { + return errors.New("\"failureLineContent\" is required but was not present") + } + // check if failureLocation (a required property) was received + if !failureLocationReceived { + return errors.New("\"failureLocation\" is required but was not present") + } + // check if failureReason (a required property) was received + if !failureReasonReceived { + return errors.New("\"failureReason\" is required but was not present") + } + // check if startTime (a required property) was received + if !startTimeReceived { + return errors.New("\"startTime\" is required but was not present") + } + // check if state (a required property) was received + if !stateReceived { + return errors.New("\"state\" is required but was not present") + } + // check if testText (a required property) was received + if !testTextReceived { + return errors.New("\"testText\" is required but was not present") + } + return nil } func (strct *Root) MarshalJSON() ([]byte, error) { buf := bytes.NewBuffer(make([]byte, 0)) buf.WriteString("{") - comma := false - // "Claim" field is required - if strct.Claim == nil { - return nil, errors.New("claim is a required field") - } - // Marshal the "claim" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"claim\": ") + comma := false + // "Claim" field is required + if strct.Claim == nil { + return nil, errors.New("claim is a required field") + } + // Marshal the "claim" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"claim\": ") if tmp, err := json.Marshal(strct.Claim); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true @@ -714,89 +717,102 @@ func (strct *Root) MarshalJSON() ([]byte, error) { } func (strct *Root) UnmarshalJSON(b []byte) error { - claimReceived := false - var jsonMap map[string]json.RawMessage - if err := json.Unmarshal(b, &jsonMap); err != nil { - return err - } - // parse all the defined properties - for k, v := range jsonMap { - switch k { - case "claim": - if err := json.Unmarshal([]byte(v), &strct.Claim); err != nil { - return err - } - claimReceived = true - default: - return fmt.Errorf("additional property not allowed: \"" + k + "\"") - } - } - // check if claim (a required property) was received - if !claimReceived { - return errors.New("\"claim\" is required but was not present") - } - return nil + claimReceived := false + var jsonMap map[string]json.RawMessage + if err := json.Unmarshal(b, &jsonMap); err != nil { + return err + } + // parse all the defined properties + for k, v := range jsonMap { + switch k { + case "claim": + if err := json.Unmarshal([]byte(v), &strct.Claim); err != nil { + return err + } + claimReceived = true + default: + return fmt.Errorf("additional property not allowed: \"" + k + "\"") + } + } + // check if claim (a required property) was received + if !claimReceived { + return errors.New("\"claim\" is required but was not present") + } + return nil } func (strct *Versions) MarshalJSON() ([]byte, error) { buf := bytes.NewBuffer(make([]byte, 0)) buf.WriteString("{") - comma := false - // Marshal the "k8s" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"k8s\": ") + comma := false + // "ClaimFormat" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "claimFormat" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"claimFormat\": ") + if tmp, err := json.Marshal(strct.ClaimFormat); err != nil { + return nil, err + } else { + buf.Write(tmp) + } + comma = true + // Marshal the "k8s" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"k8s\": ") if tmp, err := json.Marshal(strct.K8s); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // Marshal the "ocClient" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"ocClient\": ") + // Marshal the "ocClient" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"ocClient\": ") if tmp, err := json.Marshal(strct.OcClient); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // Marshal the "ocp" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"ocp\": ") + // Marshal the "ocp" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"ocp\": ") if tmp, err := json.Marshal(strct.Ocp); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // "Tnf" field is required - // only required object types supported for marshal checking (for now) - // Marshal the "tnf" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"tnf\": ") + // "Tnf" field is required + // only required object types supported for marshal checking (for now) + // Marshal the "tnf" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"tnf\": ") if tmp, err := json.Marshal(strct.Tnf); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true - // Marshal the "tnfGitCommit" field - if comma { - buf.WriteString(",") - } - buf.WriteString("\"tnfGitCommit\": ") + // Marshal the "tnfGitCommit" field + if comma { + buf.WriteString(",") + } + buf.WriteString("\"tnfGitCommit\": ") if tmp, err := json.Marshal(strct.TnfGitCommit); err != nil { return nil, err - } else { - buf.Write(tmp) + } else { + buf.Write(tmp) } comma = true @@ -806,42 +822,52 @@ func (strct *Versions) MarshalJSON() ([]byte, error) { } func (strct *Versions) UnmarshalJSON(b []byte) error { - tnfReceived := false - var jsonMap map[string]json.RawMessage - if err := json.Unmarshal(b, &jsonMap); err != nil { - return err - } - // parse all the defined properties - for k, v := range jsonMap { - switch k { - case "k8s": - if err := json.Unmarshal([]byte(v), &strct.K8s); err != nil { - return err - } - case "ocClient": - if err := json.Unmarshal([]byte(v), &strct.OcClient); err != nil { - return err - } - case "ocp": - if err := json.Unmarshal([]byte(v), &strct.Ocp); err != nil { - return err - } - case "tnf": - if err := json.Unmarshal([]byte(v), &strct.Tnf); err != nil { - return err - } - tnfReceived = true - case "tnfGitCommit": - if err := json.Unmarshal([]byte(v), &strct.TnfGitCommit); err != nil { - return err - } - default: - return fmt.Errorf("additional property not allowed: \"" + k + "\"") - } - } - // check if tnf (a required property) was received - if !tnfReceived { - return errors.New("\"tnf\" is required but was not present") - } - return nil + claimFormatReceived := false + tnfReceived := false + var jsonMap map[string]json.RawMessage + if err := json.Unmarshal(b, &jsonMap); err != nil { + return err + } + // parse all the defined properties + for k, v := range jsonMap { + switch k { + case "claimFormat": + if err := json.Unmarshal([]byte(v), &strct.ClaimFormat); err != nil { + return err + } + claimFormatReceived = true + case "k8s": + if err := json.Unmarshal([]byte(v), &strct.K8s); err != nil { + return err + } + case "ocClient": + if err := json.Unmarshal([]byte(v), &strct.OcClient); err != nil { + return err + } + case "ocp": + if err := json.Unmarshal([]byte(v), &strct.Ocp); err != nil { + return err + } + case "tnf": + if err := json.Unmarshal([]byte(v), &strct.Tnf); err != nil { + return err + } + tnfReceived = true + case "tnfGitCommit": + if err := json.Unmarshal([]byte(v), &strct.TnfGitCommit); err != nil { + return err + } + default: + return fmt.Errorf("additional property not allowed: \"" + k + "\"") + } + } + // check if claimFormat (a required property) was received + if !claimFormatReceived { + return errors.New("\"claimFormat\" is required but was not present") + } + // check if tnf (a required property) was received + if !tnfReceived { + return errors.New("\"tnf\" is required but was not present") + } + return nil } diff --git a/pkg/claim/testdata/claim-invalid-additional-property.json b/pkg/claim/testdata/claim-invalid-additional-property.json index 898f3c5..0f52ee9 100644 --- a/pkg/claim/testdata/claim-invalid-additional-property.json +++ b/pkg/claim/testdata/claim-invalid-additional-property.json @@ -6,7 +6,8 @@ "endTime": "1970-01-01T10:05:08+01:00" }, "versions": { - "tnf": "v0.0.1" + "tnf": "v0.0.1", + "claimFormat":"v0.0.1" }, "configurations": {}, "rawResults": { diff --git a/pkg/claim/testdata/claim-invalid-bool-results.json b/pkg/claim/testdata/claim-invalid-bool-results.json index 94bb6f8..ac26f4d 100644 --- a/pkg/claim/testdata/claim-invalid-bool-results.json +++ b/pkg/claim/testdata/claim-invalid-bool-results.json @@ -212,7 +212,8 @@ } }, "versions": { - "tnf": "v0.0.3" + "tnf": "v0.0.3", + "claimFormat":"v0.0.1" }, "results": false } diff --git a/pkg/claim/testdata/claim-invalid-junit-payload.json b/pkg/claim/testdata/claim-invalid-junit-payload.json index 66a8999..60a201a 100644 --- a/pkg/claim/testdata/claim-invalid-junit-payload.json +++ b/pkg/claim/testdata/claim-invalid-junit-payload.json @@ -5,7 +5,8 @@ "endTime": "1970-01-01T10:05:08+01:00" }, "versions": { - "tnf": "v0.0.1" + "tnf": "v0.0.1", + "claimFormat":"v0.0.1" }, "configurations": {}, "rawResults": false, diff --git a/pkg/claim/testdata/claim-invalid-non-result-result.json b/pkg/claim/testdata/claim-invalid-non-result-result.json index d070283..6008bcf 100644 --- a/pkg/claim/testdata/claim-invalid-non-result-result.json +++ b/pkg/claim/testdata/claim-invalid-non-result-result.json @@ -212,7 +212,8 @@ } }, "versions": { - "tnf": "v0.0.3" + "tnf": "v0.0.3", + "claimFormat":"v0.0.1" }, "results": { "{\"url\":\"https://test-network-function.com/tnf/test\",{\"version\":\"v1.0.0\"}": [ diff --git a/pkg/claim/testdata/claim-valid.json b/pkg/claim/testdata/claim-valid.json index 31395e8..c314464 100644 --- a/pkg/claim/testdata/claim-valid.json +++ b/pkg/claim/testdata/claim-valid.json @@ -212,7 +212,8 @@ } }, "versions": { - "tnf": "v0.0.3" + "tnf": "v0.0.3", + "claimFormat":"v0.0.1" }, "results": { "{\"url\":\"https://test-network-function.com/tnf/test\",{\"version\":\"v1.0.0\"}": [ diff --git a/schemas/claim.schema.json b/schemas/claim.schema.json index 4049550..2fc5444 100644 --- a/schemas/claim.schema.json +++ b/schemas/claim.schema.json @@ -135,11 +135,16 @@ "ocClient": { "type": "string", "description": "The oc client release version." + }, + "claimFormat": { + "type": "string", + "description": "The claim file format version." } }, "additionalProperties": false, "required": [ - "tnf" + "tnf", + "claimFormat" ] }, "configurations": {