Reviews: Update December 27, 2024 (#134)
This commit is contained in:
@@ -44,6 +44,7 @@ type Client struct {
|
|||||||
passes *Passes
|
passes *Passes
|
||||||
clusters *Clusters
|
clusters *Clusters
|
||||||
quants *Quants
|
quants *Quants
|
||||||
|
reviews *Reviews
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c Client) Analytics() *Analytics {
|
func (c Client) Analytics() *Analytics {
|
||||||
@@ -134,6 +135,10 @@ func (c Client) Quants() *Quants {
|
|||||||
return c.quants
|
return c.quants
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c Client) Reviews() *Reviews {
|
||||||
|
return c.reviews
|
||||||
|
}
|
||||||
|
|
||||||
type ClientOption func(c *ClientOptions)
|
type ClientOption func(c *ClientOptions)
|
||||||
|
|
||||||
func WithHttpClient(httpClient core.HttpClient) ClientOption {
|
func WithHttpClient(httpClient core.HttpClient) ClientOption {
|
||||||
@@ -200,6 +205,7 @@ func NewClient(opts ...ClientOption) *Client {
|
|||||||
passes: &Passes{client: coreClient},
|
passes: &Passes{client: coreClient},
|
||||||
clusters: &Clusters{client: coreClient},
|
clusters: &Clusters{client: coreClient},
|
||||||
quants: &Quants{client: coreClient},
|
quants: &Quants{client: coreClient},
|
||||||
|
reviews: &Reviews{client: coreClient},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -230,5 +236,6 @@ func NewMockClient(handler http.HandlerFunc) *Client {
|
|||||||
passes: &Passes{client: coreClient},
|
passes: &Passes{client: coreClient},
|
||||||
clusters: &Clusters{client: coreClient},
|
clusters: &Clusters{client: coreClient},
|
||||||
quants: &Quants{client: coreClient},
|
quants: &Quants{client: coreClient},
|
||||||
|
reviews: &Reviews{client: coreClient},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
334
ozon/reviews.go
Normal file
334
ozon/reviews.go
Normal file
@@ -0,0 +1,334 @@
|
|||||||
|
package ozon
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"net/http"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
core "github.com/diphantxm/ozon-api-client"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Reviews struct {
|
||||||
|
client *core.Client
|
||||||
|
}
|
||||||
|
|
||||||
|
type LeaveCommentParams struct {
|
||||||
|
// Review status update
|
||||||
|
MarkReviewAsProcesses bool `json:"mark_review_as_processed"`
|
||||||
|
|
||||||
|
// Identifier of the parent comment you're replying to
|
||||||
|
ParentCommentId string `json:"parent_comment_id"`
|
||||||
|
|
||||||
|
// Review identifier
|
||||||
|
ReviewId string `json:"review_id"`
|
||||||
|
|
||||||
|
// Comment text
|
||||||
|
Text string `json:"text"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type LeaveCommentResponse struct {
|
||||||
|
core.CommonResponse
|
||||||
|
|
||||||
|
// Comment identifier
|
||||||
|
CommentId string `json:"comment_id"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only available to sellers with the Premium Plus subscription
|
||||||
|
func (c Reviews) LeaveComment(ctx context.Context, params *LeaveCommentParams) (*LeaveCommentResponse, error) {
|
||||||
|
url := "/v1/review/comment/create"
|
||||||
|
|
||||||
|
resp := &LeaveCommentResponse{}
|
||||||
|
|
||||||
|
response, err := c.client.Request(ctx, http.MethodPost, url, params, resp, nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
response.CopyCommonResponse(&resp.CommonResponse)
|
||||||
|
|
||||||
|
return resp, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type DeleteCommentParams struct {
|
||||||
|
// Comment identifier
|
||||||
|
CommentId string `json:"comment_id"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type DeleteCommentResponse struct {
|
||||||
|
core.CommonResponse
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only available to sellers with the Premium Plus subscription
|
||||||
|
func (c Reviews) DeleteComment(ctx context.Context, params *DeleteCommentParams) (*DeleteCommentResponse, error) {
|
||||||
|
url := "/v1/review/comment/delete"
|
||||||
|
|
||||||
|
resp := &DeleteCommentResponse{}
|
||||||
|
|
||||||
|
response, err := c.client.Request(ctx, http.MethodPost, url, params, resp, nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
response.CopyCommonResponse(&resp.CommonResponse)
|
||||||
|
|
||||||
|
return resp, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type ListCommentsParams struct {
|
||||||
|
// Limit of values in the response. Minimum is 20. Maximum is 100
|
||||||
|
Limit int32 `json:"limit"`
|
||||||
|
|
||||||
|
// Number of elements that is skipped in the response.
|
||||||
|
// For example, if offset = 10, the response starts with the 11th element found
|
||||||
|
Offset int32 `json:"offset"`
|
||||||
|
|
||||||
|
// Review identifier
|
||||||
|
ReviewId string `json:"review_id"`
|
||||||
|
|
||||||
|
// Sorting direction
|
||||||
|
SortDir Order `json:"sort_dir"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type ListCommentsResponse struct {
|
||||||
|
core.CommonResponse
|
||||||
|
|
||||||
|
// Number of elements in the response
|
||||||
|
Offset int32 `json:"offset"`
|
||||||
|
|
||||||
|
// Comment details
|
||||||
|
Comments []Comment `json:"comments"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type Comment struct {
|
||||||
|
// Comment identifier
|
||||||
|
Id string `json:"id"`
|
||||||
|
|
||||||
|
// true, if the comment was left by an official, false if a customer left it
|
||||||
|
IsOfficial bool `json:"is_official"`
|
||||||
|
|
||||||
|
// true, if the comment was left by a seller, false if a customer left it
|
||||||
|
IsOwner bool `json:"is_owner"`
|
||||||
|
|
||||||
|
// Identifier of the parent comment to reply to
|
||||||
|
ParentCommentId string `json:"parent_comment_id"`
|
||||||
|
|
||||||
|
// Date the comment was published
|
||||||
|
PublishedAt time.Time `json:"published_at"`
|
||||||
|
|
||||||
|
// Comment text
|
||||||
|
Text string `json:"text"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only available to sellers with the Premium Plus subscription
|
||||||
|
//
|
||||||
|
// Method returns information about comments on reviews that have passed moderation
|
||||||
|
func (c Reviews) ListComments(ctx context.Context, params *ListCommentsParams) (*ListCommentsResponse, error) {
|
||||||
|
url := "/v1/review/comment/list"
|
||||||
|
|
||||||
|
resp := &ListCommentsResponse{}
|
||||||
|
|
||||||
|
response, err := c.client.Request(ctx, http.MethodPost, url, params, resp, nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
response.CopyCommonResponse(&resp.CommonResponse)
|
||||||
|
|
||||||
|
return resp, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only available to sellers with the Premium Plus subscription
|
||||||
|
type ChangeStatusParams struct {
|
||||||
|
// Array with review identifiers from 1 to 100
|
||||||
|
ReviewIds []string `json:"review_ids"`
|
||||||
|
|
||||||
|
// Review status
|
||||||
|
Status string `json:"status"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type ChangeStatusResponse struct {
|
||||||
|
core.CommonResponse
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only available to sellers with the Premium Plus subscription
|
||||||
|
func (c Reviews) ChangeStatus(ctx context.Context, params *ChangeStatusParams) (*ChangeStatusResponse, error) {
|
||||||
|
url := "/v1/review/change-status"
|
||||||
|
|
||||||
|
resp := &ChangeStatusResponse{}
|
||||||
|
|
||||||
|
response, err := c.client.Request(ctx, http.MethodPost, url, params, resp, nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
response.CopyCommonResponse(&resp.CommonResponse)
|
||||||
|
|
||||||
|
return resp, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type CountReviewsResponse struct {
|
||||||
|
core.CommonResponse
|
||||||
|
|
||||||
|
// Number of processed review
|
||||||
|
Processed int32 `json:"processed"`
|
||||||
|
|
||||||
|
// Number of all reviews
|
||||||
|
Total int32 `json:"total"`
|
||||||
|
|
||||||
|
// Number of unprocessed reviews
|
||||||
|
Unprocessed int32 `json:"unprocessed"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only available to sellers with the Premium Plus subscription
|
||||||
|
func (c Reviews) Count(ctx context.Context) (*CountReviewsResponse, error) {
|
||||||
|
url := "/v1/review/count"
|
||||||
|
|
||||||
|
resp := &CountReviewsResponse{}
|
||||||
|
|
||||||
|
response, err := c.client.Request(ctx, http.MethodPost, url, nil, resp, nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
response.CopyCommonResponse(&resp.CommonResponse)
|
||||||
|
|
||||||
|
return resp, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type GetReviewParams struct {
|
||||||
|
// Review identifier
|
||||||
|
ReviewId string `json:"review_id"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type GetReviewResponse struct {
|
||||||
|
core.CommonResponse
|
||||||
|
|
||||||
|
ReviewDetails
|
||||||
|
|
||||||
|
// Number of dislikes on the review
|
||||||
|
DislikesAmount int32 `json:"dislikes_amount"`
|
||||||
|
|
||||||
|
// Number of likes on the review
|
||||||
|
LikesAmount int32 `json:"likes_amount"`
|
||||||
|
|
||||||
|
// Image details
|
||||||
|
Photos []ReviewPhoto `json:"photos"`
|
||||||
|
|
||||||
|
// Video details
|
||||||
|
Videos []ReviewVideo `json:"videos"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type ReviewDetails struct {
|
||||||
|
// Number of comments on the review
|
||||||
|
CommentsAmount int32 `json:"comments_amount"`
|
||||||
|
|
||||||
|
// Review identifier
|
||||||
|
Id string `json:"id"`
|
||||||
|
|
||||||
|
// true, if the review affects the rating calculation
|
||||||
|
IsRatingParticipant bool `json:"is_rating_participant"`
|
||||||
|
|
||||||
|
// Status of the order for which the customer left a review
|
||||||
|
OrderStatus string `json:"order_status"`
|
||||||
|
|
||||||
|
// Number of images in the review
|
||||||
|
PhotosAmount int32 `json:"photos_amount"`
|
||||||
|
|
||||||
|
// Review publication date
|
||||||
|
PublishedAt time.Time `json:"published_at"`
|
||||||
|
|
||||||
|
// Review rating
|
||||||
|
Rating int32 `json:"rating"`
|
||||||
|
|
||||||
|
// Product identifier in the Ozon system, SKU
|
||||||
|
SKU int64 `json:"sku"`
|
||||||
|
|
||||||
|
// Review status
|
||||||
|
Status string `json:"status"`
|
||||||
|
|
||||||
|
// Review text
|
||||||
|
Text string `json:"text"`
|
||||||
|
|
||||||
|
// Number of videos for the review
|
||||||
|
VideosAmount int32 `json:"videos_amount"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type ReviewPhoto struct {
|
||||||
|
// Height
|
||||||
|
Height int32 `json:"height"`
|
||||||
|
|
||||||
|
// Link to image
|
||||||
|
URL string `json:"url"`
|
||||||
|
|
||||||
|
// Width
|
||||||
|
Width int32 `json:"width"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type ReviewVideo struct {
|
||||||
|
// Height
|
||||||
|
Height int64 `json:"height"`
|
||||||
|
|
||||||
|
// Link to video preview
|
||||||
|
PreviewURL string `json:"preview_url"`
|
||||||
|
|
||||||
|
// Link to short video
|
||||||
|
ShortVideoPreviewURL string `json:"short_video_preview_url"`
|
||||||
|
|
||||||
|
// Video link
|
||||||
|
URL string `json:"url"`
|
||||||
|
|
||||||
|
// Width
|
||||||
|
Width int64 `json:"width"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only available to sellers with the Premium Plus subscription
|
||||||
|
func (c Reviews) Get(ctx context.Context, params *GetReviewParams) (*GetReviewResponse, error) {
|
||||||
|
url := "/v1/review/info"
|
||||||
|
|
||||||
|
resp := &GetReviewResponse{}
|
||||||
|
|
||||||
|
response, err := c.client.Request(ctx, http.MethodPost, url, nil, resp, nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
response.CopyCommonResponse(&resp.CommonResponse)
|
||||||
|
|
||||||
|
return resp, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type ListReviewsParams struct {
|
||||||
|
// Identifier of the last review on the page
|
||||||
|
LastId string `json:"last_id"`
|
||||||
|
|
||||||
|
// Number of reviews in the response. Minimum is 20, maximum is 100
|
||||||
|
Limit int32 `json:"limit"`
|
||||||
|
|
||||||
|
// Sorting direction
|
||||||
|
SortDir Order `json:"sort_dir"`
|
||||||
|
|
||||||
|
// Review statuses
|
||||||
|
Status string `json:"status"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type ListReviewsResponse struct {
|
||||||
|
core.CommonResponse
|
||||||
|
|
||||||
|
// true, if not all reviews were returned in the response
|
||||||
|
HasNext bool `json:"has_next"`
|
||||||
|
|
||||||
|
// Identifier of the last review on the page
|
||||||
|
LastId string `json:"last_id"`
|
||||||
|
|
||||||
|
// Review details
|
||||||
|
Reviews []ReviewDetails `json:"reviews"`
|
||||||
|
}
|
||||||
|
|
||||||
|
// Only available to sellers with the Premium Plus subscription
|
||||||
|
func (c Reviews) List(ctx context.Context, params *ListReviewsParams) (*ListReviewsResponse, error) {
|
||||||
|
url := "/v1/review/list"
|
||||||
|
|
||||||
|
resp := &ListReviewsResponse{}
|
||||||
|
|
||||||
|
response, err := c.client.Request(ctx, http.MethodPost, url, nil, resp, nil)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
response.CopyCommonResponse(&resp.CommonResponse)
|
||||||
|
|
||||||
|
return resp, nil
|
||||||
|
}
|
||||||
416
ozon/reviews_test.go
Normal file
416
ozon/reviews_test.go
Normal file
@@ -0,0 +1,416 @@
|
|||||||
|
package ozon
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"net/http"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
core "github.com/diphantxm/ozon-api-client"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestLeaveComment(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
tests := []struct {
|
||||||
|
statusCode int
|
||||||
|
headers map[string]string
|
||||||
|
params *LeaveCommentParams
|
||||||
|
response string
|
||||||
|
}{
|
||||||
|
// Test Ok
|
||||||
|
{
|
||||||
|
http.StatusOK,
|
||||||
|
map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
|
||||||
|
&LeaveCommentParams{
|
||||||
|
MarkReviewAsProcesses: true,
|
||||||
|
ParentCommentId: "string",
|
||||||
|
ReviewId: "string1",
|
||||||
|
Text: "some string",
|
||||||
|
},
|
||||||
|
`{
|
||||||
|
"comment_id": "string"
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
// Test No Client-Id or Api-Key
|
||||||
|
{
|
||||||
|
http.StatusUnauthorized,
|
||||||
|
map[string]string{},
|
||||||
|
&LeaveCommentParams{},
|
||||||
|
`{
|
||||||
|
"code": 16,
|
||||||
|
"message": "Client-Id and Api-Key headers are required"
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, test := range tests {
|
||||||
|
c := NewMockClient(core.NewMockHttpHandler(test.statusCode, test.response, test.headers))
|
||||||
|
|
||||||
|
ctx, _ := context.WithTimeout(context.Background(), testTimeout)
|
||||||
|
resp, err := c.Reviews().LeaveComment(ctx, test.params)
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
compareJsonResponse(t, test.response, &LeaveCommentResponse{})
|
||||||
|
|
||||||
|
if resp.StatusCode != test.statusCode {
|
||||||
|
t.Errorf("got wrong status code: got: %d, expected: %d", resp.StatusCode, test.statusCode)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestDeleteComment(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
tests := []struct {
|
||||||
|
statusCode int
|
||||||
|
headers map[string]string
|
||||||
|
params *DeleteCommentParams
|
||||||
|
response string
|
||||||
|
}{
|
||||||
|
// Test Ok
|
||||||
|
{
|
||||||
|
http.StatusOK,
|
||||||
|
map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
|
||||||
|
&DeleteCommentParams{
|
||||||
|
CommentId: "string",
|
||||||
|
},
|
||||||
|
`{}`,
|
||||||
|
},
|
||||||
|
// Test No Client-Id or Api-Key
|
||||||
|
{
|
||||||
|
http.StatusUnauthorized,
|
||||||
|
map[string]string{},
|
||||||
|
&DeleteCommentParams{},
|
||||||
|
`{
|
||||||
|
"code": 16,
|
||||||
|
"message": "Client-Id and Api-Key headers are required"
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, test := range tests {
|
||||||
|
c := NewMockClient(core.NewMockHttpHandler(test.statusCode, test.response, test.headers))
|
||||||
|
|
||||||
|
ctx, _ := context.WithTimeout(context.Background(), testTimeout)
|
||||||
|
resp, err := c.Reviews().DeleteComment(ctx, test.params)
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
compareJsonResponse(t, test.response, &DeleteCommentResponse{})
|
||||||
|
|
||||||
|
if resp.StatusCode != test.statusCode {
|
||||||
|
t.Errorf("got wrong status code: got: %d, expected: %d", resp.StatusCode, test.statusCode)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestListComments(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
tests := []struct {
|
||||||
|
statusCode int
|
||||||
|
headers map[string]string
|
||||||
|
params *ListCommentsParams
|
||||||
|
response string
|
||||||
|
}{
|
||||||
|
// Test Ok
|
||||||
|
{
|
||||||
|
http.StatusOK,
|
||||||
|
map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
|
||||||
|
&ListCommentsParams{
|
||||||
|
Limit: 0,
|
||||||
|
Offset: 0,
|
||||||
|
ReviewId: "string",
|
||||||
|
SortDir: Ascending,
|
||||||
|
},
|
||||||
|
`{
|
||||||
|
"comments": [
|
||||||
|
{
|
||||||
|
"id": "string",
|
||||||
|
"is_official": true,
|
||||||
|
"is_owner": true,
|
||||||
|
"parent_comment_id": "string",
|
||||||
|
"published_at": "2019-08-24T14:15:22Z",
|
||||||
|
"text": "string"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"offset": 0
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
// Test No Client-Id or Api-Key
|
||||||
|
{
|
||||||
|
http.StatusUnauthorized,
|
||||||
|
map[string]string{},
|
||||||
|
&ListCommentsParams{},
|
||||||
|
`{
|
||||||
|
"code": 16,
|
||||||
|
"message": "Client-Id and Api-Key headers are required"
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, test := range tests {
|
||||||
|
c := NewMockClient(core.NewMockHttpHandler(test.statusCode, test.response, test.headers))
|
||||||
|
|
||||||
|
ctx, _ := context.WithTimeout(context.Background(), testTimeout)
|
||||||
|
resp, err := c.Reviews().ListComments(ctx, test.params)
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
compareJsonResponse(t, test.response, &ListCommentsResponse{})
|
||||||
|
|
||||||
|
if resp.StatusCode != test.statusCode {
|
||||||
|
t.Errorf("got wrong status code: got: %d, expected: %d", resp.StatusCode, test.statusCode)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestChangeStatus(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
tests := []struct {
|
||||||
|
statusCode int
|
||||||
|
headers map[string]string
|
||||||
|
params *ChangeStatusParams
|
||||||
|
response string
|
||||||
|
}{
|
||||||
|
// Test Ok
|
||||||
|
{
|
||||||
|
http.StatusOK,
|
||||||
|
map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
|
||||||
|
&ChangeStatusParams{
|
||||||
|
ReviewIds: []string{"string"},
|
||||||
|
Status: "PROCESSED",
|
||||||
|
},
|
||||||
|
`{}`,
|
||||||
|
},
|
||||||
|
// Test No Client-Id or Api-Key
|
||||||
|
{
|
||||||
|
http.StatusUnauthorized,
|
||||||
|
map[string]string{},
|
||||||
|
&ChangeStatusParams{},
|
||||||
|
`{
|
||||||
|
"code": 16,
|
||||||
|
"message": "Client-Id and Api-Key headers are required"
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, test := range tests {
|
||||||
|
c := NewMockClient(core.NewMockHttpHandler(test.statusCode, test.response, test.headers))
|
||||||
|
|
||||||
|
ctx, _ := context.WithTimeout(context.Background(), testTimeout)
|
||||||
|
resp, err := c.Reviews().ChangeStatus(ctx, test.params)
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
compareJsonResponse(t, test.response, &ChangeStatusResponse{})
|
||||||
|
|
||||||
|
if resp.StatusCode != test.statusCode {
|
||||||
|
t.Errorf("got wrong status code: got: %d, expected: %d", resp.StatusCode, test.statusCode)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestCountReviews(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
tests := []struct {
|
||||||
|
statusCode int
|
||||||
|
headers map[string]string
|
||||||
|
response string
|
||||||
|
}{
|
||||||
|
// Test Ok
|
||||||
|
{
|
||||||
|
http.StatusOK,
|
||||||
|
map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
|
||||||
|
`{
|
||||||
|
"processed": 2,
|
||||||
|
"total": 3,
|
||||||
|
"unprocessed": 1
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
// Test No Client-Id or Api-Key
|
||||||
|
{
|
||||||
|
http.StatusUnauthorized,
|
||||||
|
map[string]string{},
|
||||||
|
`{
|
||||||
|
"code": 16,
|
||||||
|
"message": "Client-Id and Api-Key headers are required"
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, test := range tests {
|
||||||
|
c := NewMockClient(core.NewMockHttpHandler(test.statusCode, test.response, test.headers))
|
||||||
|
|
||||||
|
ctx, _ := context.WithTimeout(context.Background(), testTimeout)
|
||||||
|
resp, err := c.Reviews().Count(ctx)
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
compareJsonResponse(t, test.response, &CountReviewsResponse{})
|
||||||
|
|
||||||
|
if resp.StatusCode != test.statusCode {
|
||||||
|
t.Errorf("got wrong status code: got: %d, expected: %d", resp.StatusCode, test.statusCode)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestGetReview(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
tests := []struct {
|
||||||
|
statusCode int
|
||||||
|
headers map[string]string
|
||||||
|
params *GetReviewParams
|
||||||
|
response string
|
||||||
|
}{
|
||||||
|
// Test Ok
|
||||||
|
{
|
||||||
|
http.StatusOK,
|
||||||
|
map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
|
||||||
|
&GetReviewParams{
|
||||||
|
ReviewId: "string",
|
||||||
|
},
|
||||||
|
`{
|
||||||
|
"comments_amount": 0,
|
||||||
|
"dislikes_amount": 0,
|
||||||
|
"id": "string",
|
||||||
|
"is_rating_participant": true,
|
||||||
|
"likes_amount": 0,
|
||||||
|
"order_status": "string",
|
||||||
|
"photos": [
|
||||||
|
{
|
||||||
|
"height": 0,
|
||||||
|
"url": "string",
|
||||||
|
"width": 0
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"photos_amount": 0,
|
||||||
|
"published_at": "2019-08-24T14:15:22Z",
|
||||||
|
"rating": 0,
|
||||||
|
"sku": 0,
|
||||||
|
"status": "string",
|
||||||
|
"text": "string",
|
||||||
|
"videos": [
|
||||||
|
{
|
||||||
|
"height": 0,
|
||||||
|
"preview_url": "string",
|
||||||
|
"short_video_preview_url": "string",
|
||||||
|
"url": "string",
|
||||||
|
"width": 0
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"videos_amount": 0
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
// Test No Client-Id or Api-Key
|
||||||
|
{
|
||||||
|
http.StatusUnauthorized,
|
||||||
|
map[string]string{},
|
||||||
|
&GetReviewParams{},
|
||||||
|
`{
|
||||||
|
"code": 16,
|
||||||
|
"message": "Client-Id and Api-Key headers are required"
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, test := range tests {
|
||||||
|
c := NewMockClient(core.NewMockHttpHandler(test.statusCode, test.response, test.headers))
|
||||||
|
|
||||||
|
ctx, _ := context.WithTimeout(context.Background(), testTimeout)
|
||||||
|
resp, err := c.Reviews().Get(ctx, test.params)
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
compareJsonResponse(t, test.response, &GetReviewResponse{})
|
||||||
|
|
||||||
|
if resp.StatusCode != test.statusCode {
|
||||||
|
t.Errorf("got wrong status code: got: %d, expected: %d", resp.StatusCode, test.statusCode)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestListReviews(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
tests := []struct {
|
||||||
|
statusCode int
|
||||||
|
headers map[string]string
|
||||||
|
params *ListReviewsParams
|
||||||
|
response string
|
||||||
|
}{
|
||||||
|
// Test Ok
|
||||||
|
{
|
||||||
|
http.StatusOK,
|
||||||
|
map[string]string{"Client-Id": "my-client-id", "Api-Key": "my-api-key"},
|
||||||
|
&ListReviewsParams{
|
||||||
|
LastId: "string",
|
||||||
|
Limit: 0,
|
||||||
|
SortDir: Ascending,
|
||||||
|
Status: "ALL",
|
||||||
|
},
|
||||||
|
`{
|
||||||
|
"has_next": true,
|
||||||
|
"last_id": "string",
|
||||||
|
"reviews": [
|
||||||
|
{
|
||||||
|
"comments_amount": 0,
|
||||||
|
"id": "string",
|
||||||
|
"is_rating_participant": true,
|
||||||
|
"order_status": "string",
|
||||||
|
"photos_amount": 0,
|
||||||
|
"published_at": "2019-08-24T14:15:22Z",
|
||||||
|
"rating": 0,
|
||||||
|
"sku": 0,
|
||||||
|
"status": "string",
|
||||||
|
"text": "string",
|
||||||
|
"videos_amount": 0
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
// Test No Client-Id or Api-Key
|
||||||
|
{
|
||||||
|
http.StatusUnauthorized,
|
||||||
|
map[string]string{},
|
||||||
|
&ListReviewsParams{},
|
||||||
|
`{
|
||||||
|
"code": 16,
|
||||||
|
"message": "Client-Id and Api-Key headers are required"
|
||||||
|
}`,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, test := range tests {
|
||||||
|
c := NewMockClient(core.NewMockHttpHandler(test.statusCode, test.response, test.headers))
|
||||||
|
|
||||||
|
ctx, _ := context.WithTimeout(context.Background(), testTimeout)
|
||||||
|
resp, err := c.Reviews().List(ctx, test.params)
|
||||||
|
if err != nil {
|
||||||
|
t.Error(err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
compareJsonResponse(t, test.response, &ListReviewsResponse{})
|
||||||
|
|
||||||
|
if resp.StatusCode != test.statusCode {
|
||||||
|
t.Errorf("got wrong status code: got: %d, expected: %d", resp.StatusCode, test.statusCode)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user