Почтальон - Как получить значение из ответа JSON для последнего появления обязательных атрибутов - PullRequest
1 голос
/ 02 апреля 2019

Я новичок в JSON и Почтальон. Я верю, что пытаюсь сделать что-то очень простое.

Я создал запрос GET, который получит JSON-ответ, подобный приведенному ниже.

В приведенном ниже примере я хочу получить значение последнего атрибута «IsArchived» (тот, который находится непосредственно перед «версией»); Или тот, который не принадлежит FieldGroup.

Как я могу это сделать? (хотя, возможно, ответит на другой мой вопрос) Заранее спасибо

{
    "Id": 1328,
    "Name": "AAA Test",
    "Owner": {
        "Id": 208,
        "Name": "The Boss"
    },
    "FieldGroups": [
        {
            "Id": "c81376f0-6ac3-4028-8d61-76a0f815dbf8",
            "Name": "General",
            "FieldDefinitions": [
                {
                    "Id": 1,
                    "DisplayName": "Product Name",
                    "IsArchived": false
                },
                {
                    "Id": 2,
                    "DisplayName": "Short Description",
                    "IsArchived": false
                },
                {
                    "Id": 33,
                    "DisplayName": "Long Description",
                    "IsArchived": false
                },
            ]
        },
        {
            "Id": "5ed8746b-0fa8-4022-8216-ad3af17db91f",
            "Name": "Somethingelse",
            "FieldDefinitions": [
                {
                    "Id": 123,
                     "DisplayName": "Attribution",
                    "IsArchived": false
                },
                {
                    "Id": 1584,
                    "DisplayName": "FC1",
                    "IsArchived": false
                },
                {
                    "Id": 623,
                    "DisplayName": "Sizes",
                    "IsArchived": false,
                    "Owner": {
                        "Id": 208,
                        "Name": "The Boss"
                    },
                    "Unit": "",
                    "Options": [
                        {
                            "Id": 1,
                            "Value": "XS"
                        },
                        {
                            "Id": 2,
                            "Value": "S"
                        },
                        {
                            "Id": 3,
                            "Value": "M"
                        },
                    ]
                }
             ]
        }
    ],
    },
    "IsArchived": false
    "Version": 1
}

Ответы [ 2 ]

0 голосов
/ 02 апреля 2019

Прежде всего, JSON, с которым вы имеете дело, недействителен. Вы всегда можете проверить действительность JSON с помощью JSONLint .

Вот правильный JSON:

{
    "Id": 1328,
    "Name": "AAA Test",
    "Owner": {
        "Id": 208,
        "Name": "The Boss"
    },
    "FieldGroups": [{
            "Id": "c81376f0-6ac3-4028-8d61-76a0f815dbf8",
            "Name": "General",
            "FieldDefinitions": [{
                    "Id": 1,
                    "DisplayName": "Product Name",
                    "IsArchived": false
                },
                {
                    "Id": 2,
                    "DisplayName": "Short Description",
                    "IsArchived": false
                },
                {
                    "Id": 33,
                    "DisplayName": "Long Description",
                    "IsArchived": false
                }
            ]
        },
        {
            "Id": "5ed8746b-0fa8-4022-8216-ad3af17db91f",
            "Name": "Somethingelse",
            "FieldDefinitions": [{
                    "Id": 123,
                    "DisplayName": "Attribution",
                    "IsArchived": false
                },
                {
                    "Id": 1584,
                    "DisplayName": "FC1",
                    "IsArchived": false
                },
                {
                    "Id": 623,
                    "DisplayName": "Sizes",
                    "IsArchived": false,
                    "Owner": {
                        "Id": 208,
                        "Name": "The Boss"
                    },
                    "Unit": "",
                    "Options": [{
                            "Id": 1,
                            "Value": "XS"
                        },
                        {
                            "Id": 2,
                            "Value": "S"
                        },
                        {
                            "Id": 3,
                            "Value": "M"
                        }
                    ]
                }
            ]
        }
    ],
    "IsArchived": false,
    "Version": 1
}

Теперь я предполагаю, что вы хотите получить атрибут в тесте Почтальона, вы можете добиться, как здесь:

var responseData = pm.response.json();
var isArchived = responseData.isArchived;
0 голосов
/ 02 апреля 2019

Это должно быть довольно просто, потому что ваш атрибут IsArchived находится на верхнем уровне ответа JSON, поэтому не случится, что будет использовано другое значение IsArchived, если вы как-то не переберите свой массив FieldGroups, как в вашемдругой вопрос.

// Convert the response body to a JSON object
var jsonData = pm.response.json()

// Create a variable and assign the value of IsArchived to it
var isArchived = jsonData.IsArchived;

// OR create a Postman environment variable and assign the value of IsArchived to it
pm.environment.set("isArchived", jsonData.IsArchived);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...