1
0
mirror of https://github.com/taigrr/wtf synced 2025-01-18 04:03:14 -08:00
2020-01-17 20:42:25 +00:00

2160 lines
82 KiB
Go

// --------------------------------------------------------------------------------------------
// Copyright (c) Microsoft Corporation. All rights reserved.
// Licensed under the MIT License.
// --------------------------------------------------------------------------------------------
// Generated file, DO NOT EDIT
// Changes may cause incorrect behavior and will be lost if the code is regenerated.
// --------------------------------------------------------------------------------------------
package test
import (
"bytes"
"context"
"encoding/json"
"github.com/google/uuid"
"github.com/microsoft/azure-devops-go-api/azuredevops"
"io"
"net/http"
"net/url"
"strconv"
"strings"
)
var ResourceAreaId, _ = uuid.Parse("c2aa639c-3ccc-4740-b3b6-ce2a1e1d984e")
type Client interface {
// Add test cases to suite.
AddTestCasesToSuite(context.Context, AddTestCasesToSuiteArgs) (*[]SuiteTestCase, error)
// Add test results to a test run.
AddTestResultsToTestRun(context.Context, AddTestResultsToTestRunArgs) (*[]TestCaseResult, error)
// [Preview API] Attach a file to a test result.
CreateTestResultAttachment(context.Context, CreateTestResultAttachmentArgs) (*TestAttachmentReference, error)
// Create new test run.
CreateTestRun(context.Context, CreateTestRunArgs) (*TestRun, error)
// [Preview API] Attach a file to a test run.
CreateTestRunAttachment(context.Context, CreateTestRunAttachmentArgs) (*TestAttachmentReference, error)
// [Preview API] Create a test session
CreateTestSession(context.Context, CreateTestSessionArgs) (*TestSession, error)
// [Preview API] Attach a file to a test result
CreateTestSubResultAttachment(context.Context, CreateTestSubResultAttachmentArgs) (*TestAttachmentReference, error)
// [Preview API] Delete a test case.
DeleteTestCase(context.Context, DeleteTestCaseArgs) error
// Delete a test run by its ID.
DeleteTestRun(context.Context, DeleteTestRunArgs) error
// Gets the action results for an iteration in a test result.
GetActionResults(context.Context, GetActionResultsArgs) (*[]TestActionResultModel, error)
// [Preview API] Get code coverage data for a build.
GetBuildCodeCoverage(context.Context, GetBuildCodeCoverageArgs) (*[]BuildCoverage, error)
// Get a test point.
GetPoint(context.Context, GetPointArgs) (*TestPoint, error)
// Get a list of test points.
GetPoints(context.Context, GetPointsArgs) (*[]TestPoint, error)
// [Preview API] Get test points using query.
GetPointsByQuery(context.Context, GetPointsByQueryArgs) (*TestPointsQuery, error)
// Get a list of parameterized results
GetResultParameters(context.Context, GetResultParametersArgs) (*[]TestResultParameterModel, error)
// [Preview API] Get test result retention settings
GetResultRetentionSettings(context.Context, GetResultRetentionSettingsArgs) (*ResultRetentionSettings, error)
// Get a specific test case in a test suite with test case id.
GetTestCaseById(context.Context, GetTestCaseByIdArgs) (*SuiteTestCase, error)
// Get all test cases in a suite.
GetTestCases(context.Context, GetTestCasesArgs) (*[]SuiteTestCase, error)
// Get iteration for a result
GetTestIteration(context.Context, GetTestIterationArgs) (*TestIterationDetailsModel, error)
// Get iterations for a result
GetTestIterations(context.Context, GetTestIterationsArgs) (*[]TestIterationDetailsModel, error)
// [Preview API] Download a test result attachment by its ID.
GetTestResultAttachmentContent(context.Context, GetTestResultAttachmentContentArgs) (io.ReadCloser, error)
// [Preview API] Get list of test result attachments reference.
GetTestResultAttachments(context.Context, GetTestResultAttachmentsArgs) (*[]TestAttachment, error)
// [Preview API] Download a test result attachment by its ID.
GetTestResultAttachmentZip(context.Context, GetTestResultAttachmentZipArgs) (io.ReadCloser, error)
// Get a test result for a test run.
GetTestResultById(context.Context, GetTestResultByIdArgs) (*TestCaseResult, error)
// Get test results for a test run.
GetTestResults(context.Context, GetTestResultsArgs) (*[]TestCaseResult, error)
// [Preview API] Download a test run attachment by its ID.
GetTestRunAttachmentContent(context.Context, GetTestRunAttachmentContentArgs) (io.ReadCloser, error)
// [Preview API] Get list of test run attachments reference.
GetTestRunAttachments(context.Context, GetTestRunAttachmentsArgs) (*[]TestAttachment, error)
// [Preview API] Download a test run attachment by its ID.
GetTestRunAttachmentZip(context.Context, GetTestRunAttachmentZipArgs) (io.ReadCloser, error)
// Get a test run by its ID.
GetTestRunById(context.Context, GetTestRunByIdArgs) (*TestRun, error)
// [Preview API] Get code coverage data for a test run
GetTestRunCodeCoverage(context.Context, GetTestRunCodeCoverageArgs) (*[]TestRunCoverage, error)
// Get a list of test runs.
GetTestRuns(context.Context, GetTestRunsArgs) (*[]TestRun, error)
// Get test run statistics , used when we want to get summary of a run by outcome.
GetTestRunStatistics(context.Context, GetTestRunStatisticsArgs) (*TestRunStatistic, error)
// [Preview API] Get a list of test sessions
GetTestSessions(context.Context, GetTestSessionsArgs) (*[]TestSession, error)
// [Preview API] Download a test sub result attachment
GetTestSubResultAttachmentContent(context.Context, GetTestSubResultAttachmentContentArgs) (io.ReadCloser, error)
// [Preview API] Get list of test sub result attachments
GetTestSubResultAttachments(context.Context, GetTestSubResultAttachmentsArgs) (*[]TestAttachment, error)
// [Preview API] Download a test sub result attachment
GetTestSubResultAttachmentZip(context.Context, GetTestSubResultAttachmentZipArgs) (io.ReadCloser, error)
// [Preview API] Get history of a test method using TestHistoryQuery
QueryTestHistory(context.Context, QueryTestHistoryArgs) (*TestHistoryQuery, error)
// Query Test Runs based on filters. Mandatory fields are minLastUpdatedDate and maxLastUpdatedDate.
QueryTestRuns(context.Context, QueryTestRunsArgs) (*QueryTestRunsResponseValue, error)
// The test points associated with the test cases are removed from the test suite. The test case work item is not deleted from the system. See test cases resource to delete a test case permanently.
RemoveTestCasesFromSuiteUrl(context.Context, RemoveTestCasesFromSuiteUrlArgs) error
// [Preview API] Update test result retention settings
UpdateResultRetentionSettings(context.Context, UpdateResultRetentionSettingsArgs) (*ResultRetentionSettings, error)
// Updates the properties of the test case association in a suite.
UpdateSuiteTestCases(context.Context, UpdateSuiteTestCasesArgs) (*[]SuiteTestCase, error)
// Update test points.
UpdateTestPoints(context.Context, UpdateTestPointsArgs) (*[]TestPoint, error)
// Update test results in a test run.
UpdateTestResults(context.Context, UpdateTestResultsArgs) (*[]TestCaseResult, error)
// Update test run by its ID.
UpdateTestRun(context.Context, UpdateTestRunArgs) (*TestRun, error)
// [Preview API] Update a test session
UpdateTestSession(context.Context, UpdateTestSessionArgs) (*TestSession, error)
}
type ClientImpl struct {
Client azuredevops.Client
}
func NewClient(ctx context.Context, connection *azuredevops.Connection) (Client, error) {
client, err := connection.GetClientByResourceAreaId(ctx, ResourceAreaId)
if err != nil {
return nil, err
}
return &ClientImpl{
Client: *client,
}, nil
}
// Add test cases to suite.
func (client *ClientImpl) AddTestCasesToSuite(ctx context.Context, args AddTestCasesToSuiteArgs) (*[]SuiteTestCase, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.PlanId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.PlanId"}
}
routeValues["planId"] = strconv.Itoa(*args.PlanId)
if args.SuiteId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.SuiteId"}
}
routeValues["suiteId"] = strconv.Itoa(*args.SuiteId)
if args.TestCaseIds == nil || *args.TestCaseIds == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.TestCaseIds"}
}
routeValues["testCaseIds"] = *args.TestCaseIds
routeValues["action"] = "TestCases"
locationId, _ := uuid.Parse("a4a1ec1c-b03f-41ca-8857-704594ecf58e")
resp, err := client.Client.Send(ctx, http.MethodPost, locationId, "5.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []SuiteTestCase
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the AddTestCasesToSuite function
type AddTestCasesToSuiteArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test plan that contains the suite.
PlanId *int
// (required) ID of the test suite to which the test cases must be added.
SuiteId *int
// (required) IDs of the test cases to add to the suite. Ids are specified in comma separated format.
TestCaseIds *string
}
// Add test results to a test run.
func (client *ClientImpl) AddTestResultsToTestRun(ctx context.Context, args AddTestResultsToTestRunArgs) (*[]TestCaseResult, error) {
if args.Results == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.Results"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
body, marshalErr := json.Marshal(*args.Results)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("4637d869-3a76-4468-8057-0bb02aa385cf")
resp, err := client.Client.Send(ctx, http.MethodPost, locationId, "5.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestCaseResult
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the AddTestResultsToTestRun function
type AddTestResultsToTestRunArgs struct {
// (required) List of test results to add.
Results *[]TestCaseResult
// (required) Project ID or project name
Project *string
// (required) Test run ID into which test results to add.
RunId *int
}
// [Preview API] Attach a file to a test result.
func (client *ClientImpl) CreateTestResultAttachment(ctx context.Context, args CreateTestResultAttachmentArgs) (*TestAttachmentReference, error) {
if args.AttachmentRequestModel == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.AttachmentRequestModel"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
body, marshalErr := json.Marshal(*args.AttachmentRequestModel)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("2bffebe9-2f0f-4639-9af8-56129e9fed2d")
resp, err := client.Client.Send(ctx, http.MethodPost, locationId, "5.1-preview.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestAttachmentReference
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the CreateTestResultAttachment function
type CreateTestResultAttachmentArgs struct {
// (required) Attachment details TestAttachmentRequestModel
AttachmentRequestModel *TestAttachmentRequestModel
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the result.
RunId *int
// (required) ID of the test result against which attachment has to be uploaded.
TestCaseResultId *int
}
// Create new test run.
func (client *ClientImpl) CreateTestRun(ctx context.Context, args CreateTestRunArgs) (*TestRun, error) {
if args.TestRun == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestRun"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
body, marshalErr := json.Marshal(*args.TestRun)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("cadb3810-d47d-4a3c-a234-fe5f3be50138")
resp, err := client.Client.Send(ctx, http.MethodPost, locationId, "5.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestRun
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the CreateTestRun function
type CreateTestRunArgs struct {
// (required) Run details RunCreateModel
TestRun *RunCreateModel
// (required) Project ID or project name
Project *string
}
// [Preview API] Attach a file to a test run.
func (client *ClientImpl) CreateTestRunAttachment(ctx context.Context, args CreateTestRunAttachmentArgs) (*TestAttachmentReference, error) {
if args.AttachmentRequestModel == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.AttachmentRequestModel"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
body, marshalErr := json.Marshal(*args.AttachmentRequestModel)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("4f004af4-a507-489c-9b13-cb62060beb11")
resp, err := client.Client.Send(ctx, http.MethodPost, locationId, "5.1-preview.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestAttachmentReference
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the CreateTestRunAttachment function
type CreateTestRunAttachmentArgs struct {
// (required) Attachment details TestAttachmentRequestModel
AttachmentRequestModel *TestAttachmentRequestModel
// (required) Project ID or project name
Project *string
// (required) ID of the test run against which attachment has to be uploaded.
RunId *int
}
// [Preview API] Create a test session
func (client *ClientImpl) CreateTestSession(ctx context.Context, args CreateTestSessionArgs) (*TestSession, error) {
if args.TestSession == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestSession"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.Team != nil && *args.Team != "" {
routeValues["team"] = *args.Team
}
body, marshalErr := json.Marshal(*args.TestSession)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("1500b4b4-6c69-4ca6-9b18-35e9e97fe2ac")
resp, err := client.Client.Send(ctx, http.MethodPost, locationId, "5.1-preview.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestSession
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the CreateTestSession function
type CreateTestSessionArgs struct {
// (required) Test session details for creation
TestSession *TestSession
// (required) Project ID or project name
Project *string
// (optional) Team ID or team name
Team *string
}
// [Preview API] Attach a file to a test result
func (client *ClientImpl) CreateTestSubResultAttachment(ctx context.Context, args CreateTestSubResultAttachmentArgs) (*TestAttachmentReference, error) {
if args.AttachmentRequestModel == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.AttachmentRequestModel"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
queryParams := url.Values{}
if args.TestSubResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "testSubResultId"}
}
queryParams.Add("testSubResultId", strconv.Itoa(*args.TestSubResultId))
body, marshalErr := json.Marshal(*args.AttachmentRequestModel)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("2bffebe9-2f0f-4639-9af8-56129e9fed2d")
resp, err := client.Client.Send(ctx, http.MethodPost, locationId, "5.1-preview.1", routeValues, queryParams, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestAttachmentReference
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the CreateTestSubResultAttachment function
type CreateTestSubResultAttachmentArgs struct {
// (required) Attachment Request Model.
AttachmentRequestModel *TestAttachmentRequestModel
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the result.
RunId *int
// (required) ID of the test results that contains sub result.
TestCaseResultId *int
// (required) ID of the test sub results against which attachment has to be uploaded.
TestSubResultId *int
}
// [Preview API] Delete a test case.
func (client *ClientImpl) DeleteTestCase(ctx context.Context, args DeleteTestCaseArgs) error {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.TestCaseId == nil {
return &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseId"}
}
routeValues["testCaseId"] = strconv.Itoa(*args.TestCaseId)
locationId, _ := uuid.Parse("4d472e0f-e32c-4ef8-adf4-a4078772889c")
_, err := client.Client.Send(ctx, http.MethodDelete, locationId, "5.1-preview.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return err
}
return nil
}
// Arguments for the DeleteTestCase function
type DeleteTestCaseArgs struct {
// (required) Project ID or project name
Project *string
// (required) Id of test case to delete.
TestCaseId *int
}
// Delete a test run by its ID.
func (client *ClientImpl) DeleteTestRun(ctx context.Context, args DeleteTestRunArgs) error {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
locationId, _ := uuid.Parse("cadb3810-d47d-4a3c-a234-fe5f3be50138")
_, err := client.Client.Send(ctx, http.MethodDelete, locationId, "5.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return err
}
return nil
}
// Arguments for the DeleteTestRun function
type DeleteTestRunArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the run to delete.
RunId *int
}
// Gets the action results for an iteration in a test result.
func (client *ClientImpl) GetActionResults(ctx context.Context, args GetActionResultsArgs) (*[]TestActionResultModel, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
if args.IterationId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.IterationId"}
}
routeValues["iterationId"] = strconv.Itoa(*args.IterationId)
if args.ActionPath != nil && *args.ActionPath != "" {
routeValues["actionPath"] = *args.ActionPath
}
locationId, _ := uuid.Parse("eaf40c31-ff84-4062-aafd-d5664be11a37")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestActionResultModel
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetActionResults function
type GetActionResultsArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the result.
RunId *int
// (required) ID of the test result that contains the iterations.
TestCaseResultId *int
// (required) ID of the iteration that contains the actions.
IterationId *int
// (optional) Path of a specific action, used to get just that action.
ActionPath *string
}
// [Preview API] Get code coverage data for a build.
func (client *ClientImpl) GetBuildCodeCoverage(ctx context.Context, args GetBuildCodeCoverageArgs) (*[]BuildCoverage, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
queryParams := url.Values{}
if args.BuildId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "buildId"}
}
queryParams.Add("buildId", strconv.Itoa(*args.BuildId))
if args.Flags == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "flags"}
}
queryParams.Add("flags", strconv.Itoa(*args.Flags))
locationId, _ := uuid.Parse("77560e8a-4e8c-4d59-894e-a5f264c24444")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []BuildCoverage
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetBuildCodeCoverage function
type GetBuildCodeCoverageArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the build for which code coverage data needs to be fetched.
BuildId *int
// (required) Value of flags determine the level of code coverage details to be fetched. Flags are additive. Expected Values are 1 for Modules, 2 for Functions, 4 for BlockData.
Flags *int
}
// Get a test point.
func (client *ClientImpl) GetPoint(ctx context.Context, args GetPointArgs) (*TestPoint, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.PlanId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.PlanId"}
}
routeValues["planId"] = strconv.Itoa(*args.PlanId)
if args.SuiteId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.SuiteId"}
}
routeValues["suiteId"] = strconv.Itoa(*args.SuiteId)
if args.PointIds == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.PointIds"}
}
routeValues["pointIds"] = strconv.Itoa(*args.PointIds)
queryParams := url.Values{}
if args.WitFields != nil {
queryParams.Add("witFields", *args.WitFields)
}
locationId, _ := uuid.Parse("3bcfd5c8-be62-488e-b1da-b8289ce9299c")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestPoint
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetPoint function
type GetPointArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test plan.
PlanId *int
// (required) ID of the suite that contains the point.
SuiteId *int
// (required) ID of the test point to get.
PointIds *int
// (optional) Comma-separated list of work item field names.
WitFields *string
}
// Get a list of test points.
func (client *ClientImpl) GetPoints(ctx context.Context, args GetPointsArgs) (*[]TestPoint, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.PlanId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.PlanId"}
}
routeValues["planId"] = strconv.Itoa(*args.PlanId)
if args.SuiteId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.SuiteId"}
}
routeValues["suiteId"] = strconv.Itoa(*args.SuiteId)
queryParams := url.Values{}
if args.WitFields != nil {
queryParams.Add("witFields", *args.WitFields)
}
if args.ConfigurationId != nil {
queryParams.Add("configurationId", *args.ConfigurationId)
}
if args.TestCaseId != nil {
queryParams.Add("testCaseId", *args.TestCaseId)
}
if args.TestPointIds != nil {
queryParams.Add("testPointIds", *args.TestPointIds)
}
if args.IncludePointDetails != nil {
queryParams.Add("includePointDetails", strconv.FormatBool(*args.IncludePointDetails))
}
if args.Skip != nil {
queryParams.Add("$skip", strconv.Itoa(*args.Skip))
}
if args.Top != nil {
queryParams.Add("$top", strconv.Itoa(*args.Top))
}
locationId, _ := uuid.Parse("3bcfd5c8-be62-488e-b1da-b8289ce9299c")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestPoint
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetPoints function
type GetPointsArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test plan.
PlanId *int
// (required) ID of the suite that contains the points.
SuiteId *int
// (optional) Comma-separated list of work item field names.
WitFields *string
// (optional) Get test points for specific configuration.
ConfigurationId *string
// (optional) Get test points for a specific test case, valid when configurationId is not set.
TestCaseId *string
// (optional) Get test points for comma-separated list of test point IDs, valid only when configurationId and testCaseId are not set.
TestPointIds *string
// (optional) Include all properties for the test point.
IncludePointDetails *bool
// (optional) Number of test points to skip..
Skip *int
// (optional) Number of test points to return.
Top *int
}
// [Preview API] Get test points using query.
func (client *ClientImpl) GetPointsByQuery(ctx context.Context, args GetPointsByQueryArgs) (*TestPointsQuery, error) {
if args.Query == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.Query"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
queryParams := url.Values{}
if args.Skip != nil {
queryParams.Add("$skip", strconv.Itoa(*args.Skip))
}
if args.Top != nil {
queryParams.Add("$top", strconv.Itoa(*args.Top))
}
body, marshalErr := json.Marshal(*args.Query)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("b4264fd0-a5d1-43e2-82a5-b9c46b7da9ce")
resp, err := client.Client.Send(ctx, http.MethodPost, locationId, "5.1-preview.2", routeValues, queryParams, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestPointsQuery
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetPointsByQuery function
type GetPointsByQueryArgs struct {
// (required) TestPointsQuery to get test points.
Query *TestPointsQuery
// (required) Project ID or project name
Project *string
// (optional) Number of test points to skip..
Skip *int
// (optional) Number of test points to return.
Top *int
}
// Get a list of parameterized results
func (client *ClientImpl) GetResultParameters(ctx context.Context, args GetResultParametersArgs) (*[]TestResultParameterModel, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
if args.IterationId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.IterationId"}
}
routeValues["iterationId"] = strconv.Itoa(*args.IterationId)
queryParams := url.Values{}
if args.ParamName != nil {
queryParams.Add("paramName", *args.ParamName)
}
locationId, _ := uuid.Parse("7c69810d-3354-4af3-844a-180bd25db08a")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestResultParameterModel
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetResultParameters function
type GetResultParametersArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the result.
RunId *int
// (required) ID of the test result that contains the iterations.
TestCaseResultId *int
// (required) ID of the iteration that contains the parameterized results.
IterationId *int
// (optional) Name of the parameter.
ParamName *string
}
// [Preview API] Get test result retention settings
func (client *ClientImpl) GetResultRetentionSettings(ctx context.Context, args GetResultRetentionSettingsArgs) (*ResultRetentionSettings, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
locationId, _ := uuid.Parse("a3206d9e-fa8d-42d3-88cb-f75c51e69cde")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue ResultRetentionSettings
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetResultRetentionSettings function
type GetResultRetentionSettingsArgs struct {
// (required) Project ID or project name
Project *string
}
// Get a specific test case in a test suite with test case id.
func (client *ClientImpl) GetTestCaseById(ctx context.Context, args GetTestCaseByIdArgs) (*SuiteTestCase, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.PlanId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.PlanId"}
}
routeValues["planId"] = strconv.Itoa(*args.PlanId)
if args.SuiteId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.SuiteId"}
}
routeValues["suiteId"] = strconv.Itoa(*args.SuiteId)
if args.TestCaseIds == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseIds"}
}
routeValues["testCaseIds"] = strconv.Itoa(*args.TestCaseIds)
routeValues["action"] = "TestCases"
locationId, _ := uuid.Parse("a4a1ec1c-b03f-41ca-8857-704594ecf58e")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue SuiteTestCase
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestCaseById function
type GetTestCaseByIdArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test plan that contains the suites.
PlanId *int
// (required) ID of the suite that contains the test case.
SuiteId *int
// (required) ID of the test case to get.
TestCaseIds *int
}
// Get all test cases in a suite.
func (client *ClientImpl) GetTestCases(ctx context.Context, args GetTestCasesArgs) (*[]SuiteTestCase, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.PlanId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.PlanId"}
}
routeValues["planId"] = strconv.Itoa(*args.PlanId)
if args.SuiteId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.SuiteId"}
}
routeValues["suiteId"] = strconv.Itoa(*args.SuiteId)
routeValues["action"] = "TestCases"
locationId, _ := uuid.Parse("a4a1ec1c-b03f-41ca-8857-704594ecf58e")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []SuiteTestCase
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestCases function
type GetTestCasesArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test plan that contains the suites.
PlanId *int
// (required) ID of the suite to get.
SuiteId *int
}
// Get iteration for a result
func (client *ClientImpl) GetTestIteration(ctx context.Context, args GetTestIterationArgs) (*TestIterationDetailsModel, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
if args.IterationId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.IterationId"}
}
routeValues["iterationId"] = strconv.Itoa(*args.IterationId)
queryParams := url.Values{}
if args.IncludeActionResults != nil {
queryParams.Add("includeActionResults", strconv.FormatBool(*args.IncludeActionResults))
}
locationId, _ := uuid.Parse("73eb9074-3446-4c44-8296-2f811950ff8d")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestIterationDetailsModel
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestIteration function
type GetTestIterationArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the result.
RunId *int
// (required) ID of the test result that contains the iterations.
TestCaseResultId *int
// (required) Id of the test results Iteration.
IterationId *int
// (optional) Include result details for each action performed in the test iteration. ActionResults refer to outcome (pass/fail) of test steps that are executed as part of a running a manual test. Including the ActionResults flag gets the outcome of test steps in the actionResults section and test parameters in the parameters section for each test iteration.
IncludeActionResults *bool
}
// Get iterations for a result
func (client *ClientImpl) GetTestIterations(ctx context.Context, args GetTestIterationsArgs) (*[]TestIterationDetailsModel, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
queryParams := url.Values{}
if args.IncludeActionResults != nil {
queryParams.Add("includeActionResults", strconv.FormatBool(*args.IncludeActionResults))
}
locationId, _ := uuid.Parse("73eb9074-3446-4c44-8296-2f811950ff8d")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestIterationDetailsModel
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestIterations function
type GetTestIterationsArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the result.
RunId *int
// (required) ID of the test result that contains the iterations.
TestCaseResultId *int
// (optional) Include result details for each action performed in the test iteration. ActionResults refer to outcome (pass/fail) of test steps that are executed as part of a running a manual test. Including the ActionResults flag gets the outcome of test steps in the actionResults section and test parameters in the parameters section for each test iteration.
IncludeActionResults *bool
}
// [Preview API] Download a test result attachment by its ID.
func (client *ClientImpl) GetTestResultAttachmentContent(ctx context.Context, args GetTestResultAttachmentContentArgs) (io.ReadCloser, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
if args.AttachmentId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.AttachmentId"}
}
routeValues["attachmentId"] = strconv.Itoa(*args.AttachmentId)
locationId, _ := uuid.Parse("2bffebe9-2f0f-4639-9af8-56129e9fed2d")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, nil, nil, "", "application/octet-stream", nil)
if err != nil {
return nil, err
}
return resp.Body, err
}
// Arguments for the GetTestResultAttachmentContent function
type GetTestResultAttachmentContentArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the testCaseResultId.
RunId *int
// (required) ID of the test result whose attachment has to be downloaded.
TestCaseResultId *int
// (required) ID of the test result attachment to be downloaded.
AttachmentId *int
}
// [Preview API] Get list of test result attachments reference.
func (client *ClientImpl) GetTestResultAttachments(ctx context.Context, args GetTestResultAttachmentsArgs) (*[]TestAttachment, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
locationId, _ := uuid.Parse("2bffebe9-2f0f-4639-9af8-56129e9fed2d")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestAttachment
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestResultAttachments function
type GetTestResultAttachmentsArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the result.
RunId *int
// (required) ID of the test result.
TestCaseResultId *int
}
// [Preview API] Download a test result attachment by its ID.
func (client *ClientImpl) GetTestResultAttachmentZip(ctx context.Context, args GetTestResultAttachmentZipArgs) (io.ReadCloser, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
if args.AttachmentId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.AttachmentId"}
}
routeValues["attachmentId"] = strconv.Itoa(*args.AttachmentId)
locationId, _ := uuid.Parse("2bffebe9-2f0f-4639-9af8-56129e9fed2d")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, nil, nil, "", "application/zip", nil)
if err != nil {
return nil, err
}
return resp.Body, err
}
// Arguments for the GetTestResultAttachmentZip function
type GetTestResultAttachmentZipArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the testCaseResultId.
RunId *int
// (required) ID of the test result whose attachment has to be downloaded.
TestCaseResultId *int
// (required) ID of the test result attachment to be downloaded.
AttachmentId *int
}
// Get a test result for a test run.
func (client *ClientImpl) GetTestResultById(ctx context.Context, args GetTestResultByIdArgs) (*TestCaseResult, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
queryParams := url.Values{}
if args.DetailsToInclude != nil {
queryParams.Add("detailsToInclude", string(*args.DetailsToInclude))
}
locationId, _ := uuid.Parse("4637d869-3a76-4468-8057-0bb02aa385cf")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestCaseResult
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestResultById function
type GetTestResultByIdArgs struct {
// (required) Project ID or project name
Project *string
// (required) Test run ID of a test result to fetch.
RunId *int
// (required) Test result ID.
TestCaseResultId *int
// (optional) Details to include with test results. Default is None. Other values are Iterations, WorkItems and SubResults.
DetailsToInclude *ResultDetails
}
// Get test results for a test run.
func (client *ClientImpl) GetTestResults(ctx context.Context, args GetTestResultsArgs) (*[]TestCaseResult, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
queryParams := url.Values{}
if args.DetailsToInclude != nil {
queryParams.Add("detailsToInclude", string(*args.DetailsToInclude))
}
if args.Skip != nil {
queryParams.Add("$skip", strconv.Itoa(*args.Skip))
}
if args.Top != nil {
queryParams.Add("$top", strconv.Itoa(*args.Top))
}
if args.Outcomes != nil {
var stringList []string
for _, item := range *args.Outcomes {
stringList = append(stringList, string(item))
}
listAsString := strings.Join((stringList)[:], ",")
queryParams.Add("definitions", listAsString)
}
locationId, _ := uuid.Parse("4637d869-3a76-4468-8057-0bb02aa385cf")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestCaseResult
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestResults function
type GetTestResultsArgs struct {
// (required) Project ID or project name
Project *string
// (required) Test run ID of test results to fetch.
RunId *int
// (optional) Details to include with test results. Default is None. Other values are Iterations and WorkItems.
DetailsToInclude *ResultDetails
// (optional) Number of test results to skip from beginning.
Skip *int
// (optional) Number of test results to return. Maximum is 1000 when detailsToInclude is None and 200 otherwise.
Top *int
// (optional) Comma separated list of test outcomes to filter test results.
Outcomes *[]TestOutcome
}
// [Preview API] Download a test run attachment by its ID.
func (client *ClientImpl) GetTestRunAttachmentContent(ctx context.Context, args GetTestRunAttachmentContentArgs) (io.ReadCloser, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.AttachmentId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.AttachmentId"}
}
routeValues["attachmentId"] = strconv.Itoa(*args.AttachmentId)
locationId, _ := uuid.Parse("4f004af4-a507-489c-9b13-cb62060beb11")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, nil, nil, "", "application/octet-stream", nil)
if err != nil {
return nil, err
}
return resp.Body, err
}
// Arguments for the GetTestRunAttachmentContent function
type GetTestRunAttachmentContentArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run whose attachment has to be downloaded.
RunId *int
// (required) ID of the test run attachment to be downloaded.
AttachmentId *int
}
// [Preview API] Get list of test run attachments reference.
func (client *ClientImpl) GetTestRunAttachments(ctx context.Context, args GetTestRunAttachmentsArgs) (*[]TestAttachment, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
locationId, _ := uuid.Parse("4f004af4-a507-489c-9b13-cb62060beb11")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestAttachment
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestRunAttachments function
type GetTestRunAttachmentsArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run.
RunId *int
}
// [Preview API] Download a test run attachment by its ID.
func (client *ClientImpl) GetTestRunAttachmentZip(ctx context.Context, args GetTestRunAttachmentZipArgs) (io.ReadCloser, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.AttachmentId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.AttachmentId"}
}
routeValues["attachmentId"] = strconv.Itoa(*args.AttachmentId)
locationId, _ := uuid.Parse("4f004af4-a507-489c-9b13-cb62060beb11")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, nil, nil, "", "application/zip", nil)
if err != nil {
return nil, err
}
return resp.Body, err
}
// Arguments for the GetTestRunAttachmentZip function
type GetTestRunAttachmentZipArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run whose attachment has to be downloaded.
RunId *int
// (required) ID of the test run attachment to be downloaded.
AttachmentId *int
}
// Get a test run by its ID.
func (client *ClientImpl) GetTestRunById(ctx context.Context, args GetTestRunByIdArgs) (*TestRun, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
queryParams := url.Values{}
if args.IncludeDetails != nil {
queryParams.Add("includeDetails", strconv.FormatBool(*args.IncludeDetails))
}
locationId, _ := uuid.Parse("cadb3810-d47d-4a3c-a234-fe5f3be50138")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestRun
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestRunById function
type GetTestRunByIdArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the run to get.
RunId *int
// (optional) Default value is true. It includes details like run statistics, release, build, test environment, post process state, and more.
IncludeDetails *bool
}
// [Preview API] Get code coverage data for a test run
func (client *ClientImpl) GetTestRunCodeCoverage(ctx context.Context, args GetTestRunCodeCoverageArgs) (*[]TestRunCoverage, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
queryParams := url.Values{}
if args.Flags == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "flags"}
}
queryParams.Add("flags", strconv.Itoa(*args.Flags))
locationId, _ := uuid.Parse("9629116f-3b89-4ed8-b358-d4694efda160")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestRunCoverage
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestRunCodeCoverage function
type GetTestRunCodeCoverageArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run for which code coverage data needs to be fetched.
RunId *int
// (required) Value of flags determine the level of code coverage details to be fetched. Flags are additive. Expected Values are 1 for Modules, 2 for Functions, 4 for BlockData.
Flags *int
}
// Get a list of test runs.
func (client *ClientImpl) GetTestRuns(ctx context.Context, args GetTestRunsArgs) (*[]TestRun, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
queryParams := url.Values{}
if args.BuildUri != nil {
queryParams.Add("buildUri", *args.BuildUri)
}
if args.Owner != nil {
queryParams.Add("owner", *args.Owner)
}
if args.TmiRunId != nil {
queryParams.Add("tmiRunId", *args.TmiRunId)
}
if args.PlanId != nil {
queryParams.Add("planId", strconv.Itoa(*args.PlanId))
}
if args.IncludeRunDetails != nil {
queryParams.Add("includeRunDetails", strconv.FormatBool(*args.IncludeRunDetails))
}
if args.Automated != nil {
queryParams.Add("automated", strconv.FormatBool(*args.Automated))
}
if args.Skip != nil {
queryParams.Add("$skip", strconv.Itoa(*args.Skip))
}
if args.Top != nil {
queryParams.Add("$top", strconv.Itoa(*args.Top))
}
locationId, _ := uuid.Parse("cadb3810-d47d-4a3c-a234-fe5f3be50138")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestRun
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestRuns function
type GetTestRunsArgs struct {
// (required) Project ID or project name
Project *string
// (optional) URI of the build that the runs used.
BuildUri *string
// (optional) Team foundation ID of the owner of the runs.
Owner *string
// (optional)
TmiRunId *string
// (optional) ID of the test plan that the runs are a part of.
PlanId *int
// (optional) If true, include all the properties of the runs.
IncludeRunDetails *bool
// (optional) If true, only returns automated runs.
Automated *bool
// (optional) Number of test runs to skip.
Skip *int
// (optional) Number of test runs to return.
Top *int
}
// Get test run statistics , used when we want to get summary of a run by outcome.
func (client *ClientImpl) GetTestRunStatistics(ctx context.Context, args GetTestRunStatisticsArgs) (*TestRunStatistic, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
locationId, _ := uuid.Parse("0a42c424-d764-4a16-a2d5-5c85f87d0ae8")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestRunStatistic
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestRunStatistics function
type GetTestRunStatisticsArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the run to get.
RunId *int
}
// [Preview API] Get a list of test sessions
func (client *ClientImpl) GetTestSessions(ctx context.Context, args GetTestSessionsArgs) (*[]TestSession, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.Team != nil && *args.Team != "" {
routeValues["team"] = *args.Team
}
queryParams := url.Values{}
if args.Period != nil {
queryParams.Add("period", strconv.Itoa(*args.Period))
}
if args.AllSessions != nil {
queryParams.Add("allSessions", strconv.FormatBool(*args.AllSessions))
}
if args.IncludeAllProperties != nil {
queryParams.Add("includeAllProperties", strconv.FormatBool(*args.IncludeAllProperties))
}
if args.Source != nil {
queryParams.Add("source", string(*args.Source))
}
if args.IncludeOnlyCompletedSessions != nil {
queryParams.Add("includeOnlyCompletedSessions", strconv.FormatBool(*args.IncludeOnlyCompletedSessions))
}
locationId, _ := uuid.Parse("1500b4b4-6c69-4ca6-9b18-35e9e97fe2ac")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestSession
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestSessions function
type GetTestSessionsArgs struct {
// (required) Project ID or project name
Project *string
// (optional) Team ID or team name
Team *string
// (optional) Period in days from now, for which test sessions are fetched.
Period *int
// (optional) If false, returns test sessions for current user. Otherwise, it returns test sessions for all users
AllSessions *bool
// (optional) If true, it returns all properties of the test sessions. Otherwise, it returns the skinny version.
IncludeAllProperties *bool
// (optional) Source of the test session.
Source *TestSessionSource
// (optional) If true, it returns test sessions in completed state. Otherwise, it returns test sessions for all states
IncludeOnlyCompletedSessions *bool
}
// [Preview API] Download a test sub result attachment
func (client *ClientImpl) GetTestSubResultAttachmentContent(ctx context.Context, args GetTestSubResultAttachmentContentArgs) (io.ReadCloser, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
if args.AttachmentId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.AttachmentId"}
}
routeValues["attachmentId"] = strconv.Itoa(*args.AttachmentId)
queryParams := url.Values{}
if args.TestSubResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "testSubResultId"}
}
queryParams.Add("testSubResultId", strconv.Itoa(*args.TestSubResultId))
locationId, _ := uuid.Parse("2bffebe9-2f0f-4639-9af8-56129e9fed2d")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, queryParams, nil, "", "application/octet-stream", nil)
if err != nil {
return nil, err
}
return resp.Body, err
}
// Arguments for the GetTestSubResultAttachmentContent function
type GetTestSubResultAttachmentContentArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the result.
RunId *int
// (required) ID of the test results that contains sub result.
TestCaseResultId *int
// (required) ID of the test result attachment to be downloaded
AttachmentId *int
// (required) ID of the test sub result whose attachment has to be downloaded
TestSubResultId *int
}
// [Preview API] Get list of test sub result attachments
func (client *ClientImpl) GetTestSubResultAttachments(ctx context.Context, args GetTestSubResultAttachmentsArgs) (*[]TestAttachment, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
queryParams := url.Values{}
if args.TestSubResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "testSubResultId"}
}
queryParams.Add("testSubResultId", strconv.Itoa(*args.TestSubResultId))
locationId, _ := uuid.Parse("2bffebe9-2f0f-4639-9af8-56129e9fed2d")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestAttachment
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the GetTestSubResultAttachments function
type GetTestSubResultAttachmentsArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the result.
RunId *int
// (required) ID of the test results that contains sub result.
TestCaseResultId *int
// (required) ID of the test sub result whose attachment has to be downloaded
TestSubResultId *int
}
// [Preview API] Download a test sub result attachment
func (client *ClientImpl) GetTestSubResultAttachmentZip(ctx context.Context, args GetTestSubResultAttachmentZipArgs) (io.ReadCloser, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
if args.TestCaseResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestCaseResultId"}
}
routeValues["testCaseResultId"] = strconv.Itoa(*args.TestCaseResultId)
if args.AttachmentId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.AttachmentId"}
}
routeValues["attachmentId"] = strconv.Itoa(*args.AttachmentId)
queryParams := url.Values{}
if args.TestSubResultId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "testSubResultId"}
}
queryParams.Add("testSubResultId", strconv.Itoa(*args.TestSubResultId))
locationId, _ := uuid.Parse("2bffebe9-2f0f-4639-9af8-56129e9fed2d")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1-preview.1", routeValues, queryParams, nil, "", "application/zip", nil)
if err != nil {
return nil, err
}
return resp.Body, err
}
// Arguments for the GetTestSubResultAttachmentZip function
type GetTestSubResultAttachmentZipArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test run that contains the result.
RunId *int
// (required) ID of the test results that contains sub result.
TestCaseResultId *int
// (required) ID of the test result attachment to be downloaded
AttachmentId *int
// (required) ID of the test sub result whose attachment has to be downloaded
TestSubResultId *int
}
// [Preview API] Get history of a test method using TestHistoryQuery
func (client *ClientImpl) QueryTestHistory(ctx context.Context, args QueryTestHistoryArgs) (*TestHistoryQuery, error) {
if args.Filter == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.Filter"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
body, marshalErr := json.Marshal(*args.Filter)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("929fd86c-3e38-4d8c-b4b6-90df256e5971")
resp, err := client.Client.Send(ctx, http.MethodPost, locationId, "5.1-preview.2", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestHistoryQuery
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the QueryTestHistory function
type QueryTestHistoryArgs struct {
// (required) TestHistoryQuery to get history
Filter *TestHistoryQuery
// (required) Project ID or project name
Project *string
}
// Query Test Runs based on filters. Mandatory fields are minLastUpdatedDate and maxLastUpdatedDate.
func (client *ClientImpl) QueryTestRuns(ctx context.Context, args QueryTestRunsArgs) (*QueryTestRunsResponseValue, error) {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
queryParams := url.Values{}
if args.MinLastUpdatedDate == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "minLastUpdatedDate"}
}
queryParams.Add("minLastUpdatedDate", (*args.MinLastUpdatedDate).String())
if args.MaxLastUpdatedDate == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "maxLastUpdatedDate"}
}
queryParams.Add("maxLastUpdatedDate", (*args.MaxLastUpdatedDate).String())
if args.State != nil {
queryParams.Add("state", string(*args.State))
}
if args.PlanIds != nil {
var stringList []string
for _, item := range *args.PlanIds {
stringList = append(stringList, strconv.Itoa(item))
}
listAsString := strings.Join((stringList)[:], ",")
queryParams.Add("definitions", listAsString)
}
if args.IsAutomated != nil {
queryParams.Add("isAutomated", strconv.FormatBool(*args.IsAutomated))
}
if args.PublishContext != nil {
queryParams.Add("publishContext", string(*args.PublishContext))
}
if args.BuildIds != nil {
var stringList []string
for _, item := range *args.BuildIds {
stringList = append(stringList, strconv.Itoa(item))
}
listAsString := strings.Join((stringList)[:], ",")
queryParams.Add("definitions", listAsString)
}
if args.BuildDefIds != nil {
var stringList []string
for _, item := range *args.BuildDefIds {
stringList = append(stringList, strconv.Itoa(item))
}
listAsString := strings.Join((stringList)[:], ",")
queryParams.Add("definitions", listAsString)
}
if args.BranchName != nil {
queryParams.Add("branchName", *args.BranchName)
}
if args.ReleaseIds != nil {
var stringList []string
for _, item := range *args.ReleaseIds {
stringList = append(stringList, strconv.Itoa(item))
}
listAsString := strings.Join((stringList)[:], ",")
queryParams.Add("definitions", listAsString)
}
if args.ReleaseDefIds != nil {
var stringList []string
for _, item := range *args.ReleaseDefIds {
stringList = append(stringList, strconv.Itoa(item))
}
listAsString := strings.Join((stringList)[:], ",")
queryParams.Add("definitions", listAsString)
}
if args.ReleaseEnvIds != nil {
var stringList []string
for _, item := range *args.ReleaseEnvIds {
stringList = append(stringList, strconv.Itoa(item))
}
listAsString := strings.Join((stringList)[:], ",")
queryParams.Add("definitions", listAsString)
}
if args.ReleaseEnvDefIds != nil {
var stringList []string
for _, item := range *args.ReleaseEnvDefIds {
stringList = append(stringList, strconv.Itoa(item))
}
listAsString := strings.Join((stringList)[:], ",")
queryParams.Add("definitions", listAsString)
}
if args.RunTitle != nil {
queryParams.Add("runTitle", *args.RunTitle)
}
if args.Top != nil {
queryParams.Add("$top", strconv.Itoa(*args.Top))
}
if args.ContinuationToken != nil {
queryParams.Add("continuationToken", *args.ContinuationToken)
}
locationId, _ := uuid.Parse("cadb3810-d47d-4a3c-a234-fe5f3be50138")
resp, err := client.Client.Send(ctx, http.MethodGet, locationId, "5.1", routeValues, queryParams, nil, "", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue QueryTestRunsResponseValue
responseValue.ContinuationToken = resp.Header.Get(azuredevops.HeaderKeyContinuationToken)
err = client.Client.UnmarshalCollectionBody(resp, &responseValue.Value)
return &responseValue, err
}
// Arguments for the QueryTestRuns function
type QueryTestRunsArgs struct {
// (required) Project ID or project name
Project *string
// (required) Minimum Last Modified Date of run to be queried (Mandatory).
MinLastUpdatedDate *azuredevops.Time
// (required) Maximum Last Modified Date of run to be queried (Mandatory, difference between min and max date can be atmost 7 days).
MaxLastUpdatedDate *azuredevops.Time
// (optional) Current state of the Runs to be queried.
State *TestRunState
// (optional) Plan Ids of the Runs to be queried, comma separated list of valid ids (limit no. of ids 10).
PlanIds *[]int
// (optional) Automation type of the Runs to be queried.
IsAutomated *bool
// (optional) PublishContext of the Runs to be queried.
PublishContext *TestRunPublishContext
// (optional) Build Ids of the Runs to be queried, comma separated list of valid ids (limit no. of ids 10).
BuildIds *[]int
// (optional) Build Definition Ids of the Runs to be queried, comma separated list of valid ids (limit no. of ids 10).
BuildDefIds *[]int
// (optional) Source Branch name of the Runs to be queried.
BranchName *string
// (optional) Release Ids of the Runs to be queried, comma separated list of valid ids (limit no. of ids 10).
ReleaseIds *[]int
// (optional) Release Definition Ids of the Runs to be queried, comma separated list of valid ids (limit no. of ids 10).
ReleaseDefIds *[]int
// (optional) Release Environment Ids of the Runs to be queried, comma separated list of valid ids (limit no. of ids 10).
ReleaseEnvIds *[]int
// (optional) Release Environment Definition Ids of the Runs to be queried, comma separated list of valid ids (limit no. of ids 10).
ReleaseEnvDefIds *[]int
// (optional) Run Title of the Runs to be queried.
RunTitle *string
// (optional) Number of runs to be queried. Limit is 100
Top *int
// (optional) continuationToken received from previous batch or null for first batch. It is not supposed to be created (or altered, if received from last batch) by user.
ContinuationToken *string
}
// Return type for the QueryTestRuns function
type QueryTestRunsResponseValue struct {
Value []TestRun
// The continuation token to be used to get the next page of results.
ContinuationToken string
}
// The test points associated with the test cases are removed from the test suite. The test case work item is not deleted from the system. See test cases resource to delete a test case permanently.
func (client *ClientImpl) RemoveTestCasesFromSuiteUrl(ctx context.Context, args RemoveTestCasesFromSuiteUrlArgs) error {
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.PlanId == nil {
return &azuredevops.ArgumentNilError{ArgumentName: "args.PlanId"}
}
routeValues["planId"] = strconv.Itoa(*args.PlanId)
if args.SuiteId == nil {
return &azuredevops.ArgumentNilError{ArgumentName: "args.SuiteId"}
}
routeValues["suiteId"] = strconv.Itoa(*args.SuiteId)
if args.TestCaseIds == nil || *args.TestCaseIds == "" {
return &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.TestCaseIds"}
}
routeValues["testCaseIds"] = *args.TestCaseIds
routeValues["action"] = "TestCases"
locationId, _ := uuid.Parse("a4a1ec1c-b03f-41ca-8857-704594ecf58e")
_, err := client.Client.Send(ctx, http.MethodDelete, locationId, "5.1", routeValues, nil, nil, "", "application/json", nil)
if err != nil {
return err
}
return nil
}
// Arguments for the RemoveTestCasesFromSuiteUrl function
type RemoveTestCasesFromSuiteUrlArgs struct {
// (required) Project ID or project name
Project *string
// (required) ID of the test plan that contains the suite.
PlanId *int
// (required) ID of the suite to get.
SuiteId *int
// (required) IDs of the test cases to remove from the suite.
TestCaseIds *string
}
// [Preview API] Update test result retention settings
func (client *ClientImpl) UpdateResultRetentionSettings(ctx context.Context, args UpdateResultRetentionSettingsArgs) (*ResultRetentionSettings, error) {
if args.RetentionSettings == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RetentionSettings"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
body, marshalErr := json.Marshal(*args.RetentionSettings)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("a3206d9e-fa8d-42d3-88cb-f75c51e69cde")
resp, err := client.Client.Send(ctx, http.MethodPatch, locationId, "5.1-preview.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue ResultRetentionSettings
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the UpdateResultRetentionSettings function
type UpdateResultRetentionSettingsArgs struct {
// (required) Test result retention settings details to be updated
RetentionSettings *ResultRetentionSettings
// (required) Project ID or project name
Project *string
}
// Updates the properties of the test case association in a suite.
func (client *ClientImpl) UpdateSuiteTestCases(ctx context.Context, args UpdateSuiteTestCasesArgs) (*[]SuiteTestCase, error) {
if args.SuiteTestCaseUpdateModel == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.SuiteTestCaseUpdateModel"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.PlanId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.PlanId"}
}
routeValues["planId"] = strconv.Itoa(*args.PlanId)
if args.SuiteId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.SuiteId"}
}
routeValues["suiteId"] = strconv.Itoa(*args.SuiteId)
if args.TestCaseIds == nil || *args.TestCaseIds == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.TestCaseIds"}
}
routeValues["testCaseIds"] = *args.TestCaseIds
routeValues["action"] = "TestCases"
body, marshalErr := json.Marshal(*args.SuiteTestCaseUpdateModel)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("a4a1ec1c-b03f-41ca-8857-704594ecf58e")
resp, err := client.Client.Send(ctx, http.MethodPatch, locationId, "5.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []SuiteTestCase
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the UpdateSuiteTestCases function
type UpdateSuiteTestCasesArgs struct {
// (required) Model for updation of the properties of test case suite association.
SuiteTestCaseUpdateModel *SuiteTestCaseUpdateModel
// (required) Project ID or project name
Project *string
// (required) ID of the test plan that contains the suite.
PlanId *int
// (required) ID of the test suite to which the test cases must be added.
SuiteId *int
// (required) IDs of the test cases to add to the suite. Ids are specified in comma separated format.
TestCaseIds *string
}
// Update test points.
func (client *ClientImpl) UpdateTestPoints(ctx context.Context, args UpdateTestPointsArgs) (*[]TestPoint, error) {
if args.PointUpdateModel == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.PointUpdateModel"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.PlanId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.PlanId"}
}
routeValues["planId"] = strconv.Itoa(*args.PlanId)
if args.SuiteId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.SuiteId"}
}
routeValues["suiteId"] = strconv.Itoa(*args.SuiteId)
if args.PointIds == nil || *args.PointIds == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.PointIds"}
}
routeValues["pointIds"] = *args.PointIds
body, marshalErr := json.Marshal(*args.PointUpdateModel)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("3bcfd5c8-be62-488e-b1da-b8289ce9299c")
resp, err := client.Client.Send(ctx, http.MethodPatch, locationId, "5.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestPoint
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the UpdateTestPoints function
type UpdateTestPointsArgs struct {
// (required) Data to update.
PointUpdateModel *PointUpdateModel
// (required) Project ID or project name
Project *string
// (required) ID of the test plan.
PlanId *int
// (required) ID of the suite that contains the points.
SuiteId *int
// (required) ID of the test point to get. Use a comma-separated list of IDs to update multiple test points.
PointIds *string
}
// Update test results in a test run.
func (client *ClientImpl) UpdateTestResults(ctx context.Context, args UpdateTestResultsArgs) (*[]TestCaseResult, error) {
if args.Results == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.Results"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
body, marshalErr := json.Marshal(*args.Results)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("4637d869-3a76-4468-8057-0bb02aa385cf")
resp, err := client.Client.Send(ctx, http.MethodPatch, locationId, "5.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue []TestCaseResult
err = client.Client.UnmarshalCollectionBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the UpdateTestResults function
type UpdateTestResultsArgs struct {
// (required) List of test results to update.
Results *[]TestCaseResult
// (required) Project ID or project name
Project *string
// (required) Test run ID whose test results to update.
RunId *int
}
// Update test run by its ID.
func (client *ClientImpl) UpdateTestRun(ctx context.Context, args UpdateTestRunArgs) (*TestRun, error) {
if args.RunUpdateModel == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunUpdateModel"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.RunId == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.RunId"}
}
routeValues["runId"] = strconv.Itoa(*args.RunId)
body, marshalErr := json.Marshal(*args.RunUpdateModel)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("cadb3810-d47d-4a3c-a234-fe5f3be50138")
resp, err := client.Client.Send(ctx, http.MethodPatch, locationId, "5.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestRun
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the UpdateTestRun function
type UpdateTestRunArgs struct {
// (required) Run details RunUpdateModel
RunUpdateModel *RunUpdateModel
// (required) Project ID or project name
Project *string
// (required) ID of the run to update.
RunId *int
}
// [Preview API] Update a test session
func (client *ClientImpl) UpdateTestSession(ctx context.Context, args UpdateTestSessionArgs) (*TestSession, error) {
if args.TestSession == nil {
return nil, &azuredevops.ArgumentNilError{ArgumentName: "args.TestSession"}
}
routeValues := make(map[string]string)
if args.Project == nil || *args.Project == "" {
return nil, &azuredevops.ArgumentNilOrEmptyError{ArgumentName: "args.Project"}
}
routeValues["project"] = *args.Project
if args.Team != nil && *args.Team != "" {
routeValues["team"] = *args.Team
}
body, marshalErr := json.Marshal(*args.TestSession)
if marshalErr != nil {
return nil, marshalErr
}
locationId, _ := uuid.Parse("1500b4b4-6c69-4ca6-9b18-35e9e97fe2ac")
resp, err := client.Client.Send(ctx, http.MethodPatch, locationId, "5.1-preview.1", routeValues, nil, bytes.NewReader(body), "application/json", "application/json", nil)
if err != nil {
return nil, err
}
var responseValue TestSession
err = client.Client.UnmarshalBody(resp, &responseValue)
return &responseValue, err
}
// Arguments for the UpdateTestSession function
type UpdateTestSessionArgs struct {
// (required) Test session details for update
TestSession *TestSession
// (required) Project ID or project name
Project *string
// (optional) Team ID or team name
Team *string
}