Как рассчитать сумму ответа (Json), используя response.path? - PullRequest
0 голосов
/ 10 января 2019

Кажется, что изо всех сил пытается вычислить количество членов отряда, которые имеют тип роли "ИГРОК", выполняя мою успокоенную логику против моего ответа Json.

В настоящее время у меня есть простая настройка, которая достигает конечной точки, а затем выполняет мой запрос. Я вижу, что конечная точка и ответ действительны, однако при попытке фильтрации по моему запросу возникает проблема, чтобы вычислить общую сумму членов команды, играющих роль «ИГРОКА».

Код моего отдыха:

@Test
public void locatePlayerCalculateSum() {
    Response response = given()
            .spec(footballCompetitions_requestSpecification)
            .when().get(EndPoint.TEAMS + EndPoint.SQUAD);
    int sum = response.path("squad.collect { it.role == \"PLAYER\" }.sum()");
    System.out.println(sum);
}

Сообщение об исключении: java.lang.IllegalArgumentException: Нет подписи метода: java.lang.Boolean.plus () применим для типов аргументов: (java.lang.Boolean) значения: [true] Возможные решения: is (java.lang.Object) или (java.lang.Boolean), подразумевает (java.lang.Boolean) и (java.lang.Boolean), использовать ([Ljava.lang.Object;), раскол (groovy.lang.Closure)

Пример ответа JSON:

  "id": 66,
  "area": {
      "id": 2072,
      "name": "England"
  },
  "activeCompetitions": [
      {
          "id": 2021,
          "area": {
              "id": 2072,
              "name": "England"
          },
          "name": "Premier League",
          "code": "PL",
          "plan": "TIER_ONE",
          "lastUpdated": "2019-01-03T23:39:45Z"
      },
      {
          "id": 2001,
          "area": {
              "id": 2077,
              "name": "Europe"
          },
          "name": "UEFA Champions League",
          "code": "CL",
          "plan": "TIER_ONE",
          "lastUpdated": "2018-12-13T18:55:02Z"
      }
  ],
  "name": "Manchester United FC",
  "shortName": "Man United",
  "tla": "MNU",
  "crestUrl": "http://upload.wikimedia.org/wikipedia/de/d/da/Manchester_United_FC.svg",
  "address": "Sir Matt Busby Way Manchester M16 0RA",
  "phone": "+44 (0161) 8688000",
  "website": "http://www.manutd.com",
  "email": "enquiries@manutd.co.uk",
  "founded": 1878,
  "clubColors": "Red / White",
  "venue": "Old Trafford",
  "squad": [
      {
          "id": 3188,
          "name": "David De Gea",
          "position": "Goalkeeper",
          "dateOfBirth": "1990-11-07T00:00:00Z",
          "countryOfBirth": "Spain",
          "nationality": "Spain",
          "shirtNumber": 1,
          "role": "PLAYER"
      },
      {
          "id": 3202,
          "name": "Sergio Romero",
          "position": "Goalkeeper",
          "dateOfBirth": "1987-02-22T00:00:00Z",
          "countryOfBirth": "Argentina",
          "nationality": "Argentina",
          "shirtNumber": null,
          "role": "PLAYER"
      },
      {
          "id": 7942,
          "name": "Lee Grant",
          "position": "Goalkeeper",
          "dateOfBirth": "1983-01-27T00:00:00Z",
          "countryOfBirth": "England",
          "nationality": "England",
          "shirtNumber": 13,
          "role": "PLAYER"
      },
      {
          "id": 3206,
          "name": "Marcos Rojo",
          "position": "Defender",
          "dateOfBirth": "1990-03-20T00:00:00Z",
          "countryOfBirth": "Argentina",
          "nationality": "Argentina",
          "shirtNumber": 16,
          "role": "PLAYER"
      },```


1 Ответ

0 голосов
/ 10 января 2019

Это должно работать:

@Test
public void locatePlayerCalculateSum() {
    Response response = given()
            .spec(footballCompetitions_requestSpecification)
            .when().get(EndPoint.TEAMS + EndPoint.SQUAD);
    int sum = response.path("squad.count { it.role == 'PLAYER' }");
    System.out.println(sum);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...