mirror of
https://github.com/OpenMaxIO/openmaxio-object-browser
synced 2026-07-01 07:41:18 -07:00
Table tests for site replication apis (#1944)
This commit is contained in:
committed by
GitHub
parent
42beef408c
commit
3c659a29ae
@@ -60,8 +60,75 @@ func makeExecuteReq(method string, body io.Reader) (*http.Response, error) {
|
|||||||
return response, nil
|
return response, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func AddSiteReplicationInfo() (*http.Response, error) {
|
func AddSiteReplicationInfo(sites []map[string]interface{}) (int, error) {
|
||||||
|
requestDataJSON, _ := json.Marshal(sites)
|
||||||
|
requestDataBody := bytes.NewReader(requestDataJSON)
|
||||||
|
response, err := makeExecuteReq("POST", requestDataBody)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
log.Println(response)
|
||||||
|
return -1, err
|
||||||
|
}
|
||||||
|
if response != nil {
|
||||||
|
return response.StatusCode, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func EditSiteReplicationInfo(editedSite map[string]interface{}) (int, error) {
|
||||||
|
requestDataJSON, _ := json.Marshal(editedSite)
|
||||||
|
requestDataBody := bytes.NewReader(requestDataJSON)
|
||||||
|
response, err := makeExecuteReq("PUT", requestDataBody)
|
||||||
|
|
||||||
|
fmt.Println(response, err)
|
||||||
|
if err != nil {
|
||||||
|
return -1, err
|
||||||
|
}
|
||||||
|
if response != nil {
|
||||||
|
return response.StatusCode, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1, nil
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func DeleteSiteReplicationInfo(delReq map[string]interface{}) (int, error) {
|
||||||
|
|
||||||
|
requestDataJSON, _ := json.Marshal(delReq)
|
||||||
|
requestDataBody := bytes.NewReader(requestDataJSON)
|
||||||
|
|
||||||
|
response, err := makeExecuteReq("DELETE", requestDataBody)
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
log.Println(response)
|
||||||
|
return -1, err
|
||||||
|
}
|
||||||
|
if response != nil {
|
||||||
|
return response.StatusCode, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1, nil
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestGetSiteReplicationInfo(t *testing.T) {
|
||||||
|
assert := assert.New(t)
|
||||||
|
response, err := makeExecuteReq("GET", nil)
|
||||||
|
tgt := &models.SiteReplicationInfoResponse{}
|
||||||
|
json.NewDecoder(response.Body).Decode(tgt)
|
||||||
|
if err != nil {
|
||||||
|
log.Println(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if response != nil {
|
||||||
|
assert.Equal(200, response.StatusCode, "Status Code is incorrect")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestAddSiteReplicationInfo(t *testing.T) {
|
||||||
|
assert := assert.New(t)
|
||||||
|
fmt.Println("Add Site Replication")
|
||||||
sites := make([]map[string]interface{}, 2)
|
sites := make([]map[string]interface{}, 2)
|
||||||
sites[0] = map[string]interface{}{
|
sites[0] = map[string]interface{}{
|
||||||
"accessKey": "minioadmin",
|
"accessKey": "minioadmin",
|
||||||
@@ -71,56 +138,169 @@ func AddSiteReplicationInfo() (*http.Response, error) {
|
|||||||
}
|
}
|
||||||
sites[1] = map[string]interface{}{
|
sites[1] = map[string]interface{}{
|
||||||
"accessKey": "minioadmin",
|
"accessKey": "minioadmin",
|
||||||
"endpoint": "http://minio1:9001",
|
"endpoint": "http://minio1:9001", //Docker container .
|
||||||
|
// "endpoint": "http://localhost:9001", for local development
|
||||||
"secretKey": "minioadmin",
|
"secretKey": "minioadmin",
|
||||||
"name": "sitellhost9001",
|
"name": "sitellhost9001",
|
||||||
}
|
}
|
||||||
|
|
||||||
requestDataJSON, _ := json.Marshal(sites)
|
errorSites1 := make([]map[string]interface{}, 2)
|
||||||
requestDataBody := bytes.NewReader(requestDataJSON)
|
errorSites1[0] = map[string]interface{}{
|
||||||
|
"accessKey": "minioadmin",
|
||||||
return makeExecuteReq("POST", requestDataBody)
|
"endpoint": "http://localhost:9000",
|
||||||
|
"secretKey": "minioadmin",
|
||||||
}
|
"name": "sitellhost9000",
|
||||||
|
}
|
||||||
func EditSiteReplicationInfo() (*http.Response, error) {
|
errorSites1[1] = map[string]interface{}{
|
||||||
|
"accessKey": "minioadmin",
|
||||||
getResponse, err := makeExecuteReq("GET", nil)
|
"endpoint": "http://non-existent:9001",
|
||||||
//defer response.Body.Close()
|
"secretKey": "minioadmin",
|
||||||
|
"name": "sitellhost9001",
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
errorSites2 := make([]map[string]interface{}, 2)
|
||||||
|
errorSites2[0] = map[string]interface{}{
|
||||||
|
"accessKey": "minioadmin",
|
||||||
|
"endpoint": "http://localhost:9000",
|
||||||
|
"secretKey": "minioadmin",
|
||||||
|
"name": "sitellhost9000",
|
||||||
|
}
|
||||||
|
errorSites2[1] = map[string]interface{}{
|
||||||
|
"accessKey": "minioadmin",
|
||||||
|
"endpoint": "http://localhost:9000",
|
||||||
|
"secretKey": "minioadmin",
|
||||||
|
"name": "sitellhost9000",
|
||||||
|
}
|
||||||
|
type args struct {
|
||||||
|
sites []map[string]interface{}
|
||||||
|
}
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
args args
|
||||||
|
expStatusCode int
|
||||||
|
expectedError bool
|
||||||
|
}{
|
||||||
|
// valid sites for replication config
|
||||||
|
{
|
||||||
|
name: "Add Two sites for Replication",
|
||||||
|
args: args{
|
||||||
|
sites: sites,
|
||||||
|
},
|
||||||
|
expStatusCode: 200,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
|
||||||
|
//context deadline error
|
||||||
|
{
|
||||||
|
name: "Add Invalid Site name for Replication",
|
||||||
|
args: args{
|
||||||
|
sites: errorSites1,
|
||||||
|
},
|
||||||
|
expStatusCode: 0,
|
||||||
|
expectedError: true,
|
||||||
|
},
|
||||||
|
//site already added error 500
|
||||||
|
{
|
||||||
|
name: "Add same Site name for Replication",
|
||||||
|
args: args{
|
||||||
|
sites: errorSites2,
|
||||||
|
},
|
||||||
|
expStatusCode: 500,
|
||||||
|
expectedError: true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
actualStatusCode, err := AddSiteReplicationInfo(tt.args.sites)
|
||||||
|
fmt.Println("TestAddSiteReplicationInfo: ", actualStatusCode)
|
||||||
|
|
||||||
|
if tt.expStatusCode > 0 {
|
||||||
|
assert.Equal(tt.expStatusCode, actualStatusCode, "Expected Status Code is incorrect")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if tt.expectedError {
|
||||||
|
assert.NotEmpty(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestEditSiteReplicationInfo(t *testing.T) {
|
||||||
|
assert := assert.New(t)
|
||||||
|
getResponse, err := makeExecuteReq("GET", nil)
|
||||||
|
if err != nil {
|
||||||
|
assert.Fail("Unable to get Site replication info")
|
||||||
|
}
|
||||||
getResObj := &models.SiteReplicationInfoResponse{}
|
getResObj := &models.SiteReplicationInfoResponse{}
|
||||||
json.NewDecoder(getResponse.Body).Decode(getResObj)
|
json.NewDecoder(getResponse.Body).Decode(getResObj)
|
||||||
|
|
||||||
//fmt.Println("Edit Got::", getResObj, getResObj.Sites[0], getResObj.Sites[1])
|
|
||||||
var secondDeploymentID string
|
var secondDeploymentID string
|
||||||
if getResObj != nil {
|
if getResObj != nil {
|
||||||
if len(getResObj.Sites) > 0 {
|
if len(getResObj.Sites) > 0 {
|
||||||
secondDeploymentID = getResObj.Sites[1].DeploymentID
|
secondDeploymentID = getResObj.Sites[1].DeploymentID
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return nil, nil
|
assert.Fail("Unable to get Site deployment info")
|
||||||
}
|
}
|
||||||
|
fmt.Println("Edit Site Replication")
|
||||||
fmt.Println("Editing::", getResObj.Sites[1])
|
fmt.Println("Editing a valid site deployment id::", secondDeploymentID)
|
||||||
fmt.Println("Editing::", secondDeploymentID)
|
updatedSiteInfo := map[string]interface{}{
|
||||||
pSiteInfo := map[string]interface{}{
|
|
||||||
"deploymentID": secondDeploymentID,
|
"deploymentID": secondDeploymentID,
|
||||||
"endpoint": "http://minio2:9002",
|
"endpoint": "http://minio2:9002", //replace it with docker name
|
||||||
|
//"endpoint": "http://localhost:9002", //local dev
|
||||||
|
"name": "sitellhost9002",
|
||||||
|
}
|
||||||
|
invalidUpdatedSiteInfo := map[string]interface{}{
|
||||||
|
"deploymentID": secondDeploymentID,
|
||||||
|
"endpoint": "non-existenet:9002",
|
||||||
"name": "sitellhost9002",
|
"name": "sitellhost9002",
|
||||||
}
|
}
|
||||||
|
invalidUpdatedSiteInfo1 := map[string]interface{}{}
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
args map[string]interface{}
|
||||||
|
expStatusCode int
|
||||||
|
expectedError bool
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "Edit an existing valid site",
|
||||||
|
args: updatedSiteInfo,
|
||||||
|
expStatusCode: -1,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Edit with an invalid site endpoint",
|
||||||
|
args: invalidUpdatedSiteInfo,
|
||||||
|
expStatusCode: -1,
|
||||||
|
expectedError: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Edit with an invalid empty site ",
|
||||||
|
args: invalidUpdatedSiteInfo1,
|
||||||
|
expStatusCode: 500,
|
||||||
|
expectedError: true,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
actualStatusCode, err := EditSiteReplicationInfo(tt.args)
|
||||||
|
fmt.Println("TestEditSiteReplicationInfo: ", actualStatusCode)
|
||||||
|
if tt.expStatusCode > 0 {
|
||||||
|
assert.Equal(tt.expStatusCode, actualStatusCode, "Expected Status Code is incorrect")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if tt.expectedError {
|
||||||
|
assert.NotEmpty(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
requestDataJSON, _ := json.Marshal(pSiteInfo)
|
})
|
||||||
requestDataBody := bytes.NewReader(requestDataJSON)
|
}
|
||||||
return makeExecuteReq("PUT", requestDataBody)
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func DeleteSiteReplicationInfo() (*http.Response, error) {
|
func TestDeleteSiteReplicationInfo(t *testing.T) {
|
||||||
|
assert := assert.New(t)
|
||||||
delReq := map[string]interface{}{
|
delReq := map[string]interface{}{
|
||||||
"all": true,
|
"all": true,
|
||||||
"sites": []string{
|
"sites": []string{
|
||||||
@@ -129,89 +309,64 @@ func DeleteSiteReplicationInfo() (*http.Response, error) {
|
|||||||
"sitellhost9002",
|
"sitellhost9002",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
requestDataJSON, _ := json.Marshal(delReq)
|
invalidDelReq := map[string]interface{}{
|
||||||
requestDataBody := bytes.NewReader(requestDataJSON)
|
"all": false,
|
||||||
|
"sites": []string{
|
||||||
return makeExecuteReq("DELETE", requestDataBody)
|
"sitellhost9000",
|
||||||
|
},
|
||||||
}
|
|
||||||
|
|
||||||
func TestGetSiteReplicationInfo(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
|
|
||||||
response, err := makeExecuteReq("GET", nil)
|
|
||||||
//defer response.Body.Close()
|
|
||||||
|
|
||||||
tgt := &models.SiteReplicationInfoResponse{}
|
|
||||||
json.NewDecoder(response.Body).Decode(tgt)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
log.Println(err)
|
|
||||||
return
|
|
||||||
}
|
}
|
||||||
if response != nil {
|
invalidDelReq1 := map[string]interface{}{
|
||||||
assert.Equal(200, response.StatusCode, "Status Code is incorrect")
|
"all": true,
|
||||||
|
"sites": []string{},
|
||||||
}
|
}
|
||||||
|
tests := []struct {
|
||||||
}
|
name string
|
||||||
|
args map[string]interface{}
|
||||||
func TestAddSiteReplicationInfo(t *testing.T) {
|
expStatusCode int
|
||||||
assert := assert.New(t)
|
expectedError bool
|
||||||
|
}{
|
||||||
fmt.Println("Add Site Replication")
|
{
|
||||||
response, err := AddSiteReplicationInfo()
|
name: "Delete Valid Sites already added",
|
||||||
|
args: delReq,
|
||||||
if err != nil {
|
expStatusCode: 204,
|
||||||
log.Println(err)
|
expectedError: false,
|
||||||
return
|
},
|
||||||
|
{
|
||||||
|
name: "Delete Invalid Sites ",
|
||||||
|
args: invalidDelReq,
|
||||||
|
expStatusCode: 500,
|
||||||
|
expectedError: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Invalid delete request",
|
||||||
|
args: invalidDelReq1,
|
||||||
|
expStatusCode: 500,
|
||||||
|
expectedError: true,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
if response != nil {
|
|
||||||
assert.Equal(200, response.StatusCode, "Status Code is incorrect")
|
|
||||||
}
|
|
||||||
fmt.Println("TestAddSiteReplicationInfo: ", response.StatusCode)
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestEditSiteReplicationInfo(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
|
|
||||||
response, err := EditSiteReplicationInfo()
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
log.Println(err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if response != nil {
|
|
||||||
assert.NotEmpty(response)
|
|
||||||
assert.Equal(200, response.StatusCode, "Status Code is incorrect")
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestDeleteSiteReplicationInfo(t *testing.T) {
|
|
||||||
assert := assert.New(t)
|
|
||||||
|
|
||||||
fmt.Println("Delete Site Replication")
|
fmt.Println("Delete Site Replication")
|
||||||
response, err := DeleteSiteReplicationInfo()
|
for _, tt := range tests {
|
||||||
if err != nil {
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
log.Println(err)
|
actualStatusCode, err := DeleteSiteReplicationInfo(tt.args)
|
||||||
return
|
fmt.Println("TestDeleteSiteReplicationInfo: ", actualStatusCode)
|
||||||
|
if tt.expStatusCode > 0 {
|
||||||
|
assert.Equal(tt.expStatusCode, actualStatusCode, "Expected Status Code is incorrect")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if tt.expectedError {
|
||||||
|
assert.NotEmpty(err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
})
|
||||||
}
|
}
|
||||||
if response != nil {
|
|
||||||
assert.Equal(204, response.StatusCode, "Status Code is incorrect")
|
|
||||||
}
|
|
||||||
fmt.Println("TestDeleteReplicationInfo: ", response.StatusCode)
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Status API
|
// Status API
|
||||||
|
|
||||||
func makeStatusExecuteReq(method string, url string) (*http.Response, error) {
|
func makeStatusExecuteReq(method string, url string) (*http.Response, error) {
|
||||||
|
|
||||||
client := &http.Client{
|
client := &http.Client{
|
||||||
Timeout: 10 * time.Second,
|
Timeout: 10 * time.Second,
|
||||||
}
|
}
|
||||||
|
|
||||||
request, err := http.NewRequest(
|
request, err := http.NewRequest(
|
||||||
method,
|
method,
|
||||||
url,
|
url,
|
||||||
@@ -224,43 +379,101 @@ func makeStatusExecuteReq(method string, url string) (*http.Response, error) {
|
|||||||
request.Header.Add("Cookie", fmt.Sprintf("token=%s", token))
|
request.Header.Add("Cookie", fmt.Sprintf("token=%s", token))
|
||||||
request.Header.Add("Content-Type", "application/json")
|
request.Header.Add("Content-Type", "application/json")
|
||||||
response, err := client.Do(request)
|
response, err := client.Do(request)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
return response, nil
|
return response, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestGetSiteReplicationStatus(t *testing.T) {
|
func TestGetSiteReplicationStatus(t *testing.T) {
|
||||||
assert := assert.New(t)
|
assert := assert.New(t)
|
||||||
|
|
||||||
reqUrls := [5]string{
|
const (
|
||||||
//default
|
baseAPIURL = "http://localhost:9090/api/v1/admin/site-replication/status?"
|
||||||
"http://localhost:9090/api/v1/admin/site-replication/status?users=true&groups=true&buckets=true&policies=true",
|
lookupDefaultParams = "users=false&groups=false&buckets=false&policies=false&"
|
||||||
//specific bucket lookup
|
)
|
||||||
"http://localhost:9090/api/v1/admin/site-replication/status?users=false&groups=false&buckets=false&policies=false&entityValue=test-bucket&entityType=bucket",
|
|
||||||
//specific-user lookup
|
tests := []struct {
|
||||||
"http://localhost:9090/api/v1/admin/site-replication/status?users=false&groups=false&buckets=false&policies=false&entityValue=test-user&entityType=user",
|
name string
|
||||||
//specific-group lookup
|
args string
|
||||||
"http://localhost:9090/api/v1/admin/site-replication/status?users=false&groups=false&buckets=false&policies=false&entityValue=test-group&entityType=group",
|
expStatusCode int
|
||||||
//specific-policy lookup
|
expectedError bool
|
||||||
"http://localhost:9090/api/v1/admin/site-replication/status?users=false&groups=false&buckets=false&policies=false&entityValue=test-policies&entityType=policiy",
|
}{
|
||||||
|
|
||||||
|
{
|
||||||
|
name: "Default replication status",
|
||||||
|
args: baseAPIURL + "users=true&groups=true&buckets=true&policies=true",
|
||||||
|
expStatusCode: 200,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Specific bucket lookup replication status",
|
||||||
|
args: baseAPIURL + lookupDefaultParams + "entityValue=test-bucket&entityType=bucket",
|
||||||
|
expStatusCode: 200,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Invalid specific bucket lookup replication status",
|
||||||
|
args: baseAPIURL + lookupDefaultParams + "entityValue=test-bucket-non-existent&entityType=bucket",
|
||||||
|
expStatusCode: 200,
|
||||||
|
expectedError: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Specific user lookup replication status",
|
||||||
|
args: baseAPIURL + lookupDefaultParams + "entityValue=test-user&entityType=user",
|
||||||
|
expStatusCode: 200,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Invalid user lookup replication status",
|
||||||
|
args: baseAPIURL + lookupDefaultParams + "entityValue=test-user-non-existent&entityType=user",
|
||||||
|
expStatusCode: 200,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Specific group lookup replication status",
|
||||||
|
args: baseAPIURL + lookupDefaultParams + "entityValue=test-group&entityType=group",
|
||||||
|
expStatusCode: 200,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Invalid group lookup replication status",
|
||||||
|
args: baseAPIURL + lookupDefaultParams + "entityValue=test-group-non-existent&entityType=group",
|
||||||
|
expStatusCode: 200,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Specific policy replication status",
|
||||||
|
args: baseAPIURL + lookupDefaultParams + "entityValue=consoleAdmin&entityType=policy",
|
||||||
|
expStatusCode: 200,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "Invalid policy replication status",
|
||||||
|
args: baseAPIURL + lookupDefaultParams + "entityValue=test-policies&entityType=policy",
|
||||||
|
expStatusCode: 200,
|
||||||
|
expectedError: false,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for i, url := range reqUrls {
|
for ti, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
response, err := makeStatusExecuteReq("GET", tt.args)
|
||||||
|
tgt := &models.SiteReplicationStatusResponse{}
|
||||||
|
json.NewDecoder(response.Body).Decode(tgt)
|
||||||
|
log.Println(err, response)
|
||||||
|
if err != nil {
|
||||||
|
log.Println(err)
|
||||||
|
|
||||||
response, err := makeStatusExecuteReq("GET", url)
|
if tt.expectedError {
|
||||||
|
assert.NotEmpty(err)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if response != nil {
|
||||||
|
assert.Equal(tt.expStatusCode, response.StatusCode, "Status Code for", ti)
|
||||||
|
}
|
||||||
|
|
||||||
tgt := &models.SiteReplicationStatusResponse{}
|
})
|
||||||
json.NewDecoder(response.Body).Decode(tgt)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
log.Println(err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
if response != nil {
|
|
||||||
assert.Equal(200, response.StatusCode, "Status Code for", i)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user