Соответствие шаблону для отдельных параметров в пакт-потребительских тестах

Использование pact-jvm - Java

поэтому у нас есть API, который отвечает десятичными / плавающими значениями для нескольких параметров. "body": { "status": "api is up.", "totalTime": 0.005939006805419922 }"Я попытался с помощью регулярного выражения, но тело pact сгенерировало данные, и это было несоответствие десятичному числу, возвращенному фактическим API.

package pact;
import au.com.dius.pact.consumer.dsl.DslPart;
import au.com.dius.pact.consumer.dsl.PactDslJsonBody;
import au.com.dius.pact.consumer.dsl.PactDslWithProvider;
import au.com.dius.pact.model.PactFragment;
import au.com.dius.pact.consumer.ConsumerPactTest;
import java.util.Map;
import java.util.HashMap;
import au.com.dius.pact.consumer.PactProviderRule;
import static org.hamcrest.MatcherAssert.assertThat;
import static org.hamcrest.Matchers.hasKey;
import static org.hamcrest.Matchers.is;
import static org.hamcrest.Matchers.nullValue;
import org.junit.Rule;
import au.com.dius.pact.consumer.dsl.PactDslJsonArray;

public class PactTest extends ConsumerPactTest {

    @Rule
    public PactProviderRule mockProvider = new PactProviderRule("test_provider", "localhost", 1234, this);
    String v3Path = "/v3";
    private DslPart body = new PactDslJsonBody()
            .stringType("status", "api is up.")
            .decimalType("totalTime", 0.005939006805419922);

    protected PactFragment createFragment(PactDslWithProvider builder) {
        Map<String, String> headers = new HashMap<String, String>();
        headers.put("Content-Type", "application/json");

        PactFragment fragment = builder
                .uponReceiving("response")
                .path(v3Path)
                .method("GET")
                .willRespondWith()
                .status(200)
                .headers(headers)
                .body(body)
                .toFragment();
        return fragment;
    }

    @Override
    protected String providerName() {
        return "test_provider";
    }

    @Override
    protected String consumerName() {
        return "test_consumer";
    }

    @Override
    protected void runTest(String url) {
        Map response;
        try {
            response = new ConsumerClient(url).getAsMap(v3Path, "");
        } catch (Exception e) {
            throw new RuntimeException(e);
        }
    }
}

Пакт генерируется:

{
"provider": {
    "name": "test_provider"
},
"consumer": {
    "name": "test_consumer"
},
"interactions": [
    {
        "description": "API v3 endpoint response",
        "request": {
            "method": "GET",
            "path": "/v3"
        },
        "response": {
            "status": 200,
            "headers": {
                "Content-Type": "application/json"
            },
            "body": {
                "status": "api is up.",
                "totalTime": 0.005939006805419922
            },
            "matchingRules": {
                "body": {
                    "$.status": {
                        "matchers": [
                            {
                                "match": "type"
                            }
                        ]
                    },
                    "$.totalTime": {
                        "matchers": [
                            {
                                "match": "decimal"
                            }
                        ]
                    }
                }
            }
        }
    }
],
"metadata": {
    "pact-specification": {
        "version": "3.0.0"
    },
    "pact-jvm": {
        "version": "3.5.0-beta.2"
    }
}

}

Разница между пактом и фактическим ответом:

0) Verifying a pact between test_consumer and test_provider - API v3 endpoint response returns a response which has a matching body
  $.body.totalTime -> Expected 0.005939006805419922 but received 0.00545501708984375

Diff:

  @1
      "status": "api is up.",
  -    "totalTime": 0.005939006805419922
  +    "totalTime": 0.00545501708984375
  }

так возможно ли сделать "eachlike" вместо decimalType, чтобы соответствовать шаблонам этих значений? как я посмотрел на каждый лайк, и он принимает строку и int - https://github.com/DiUS/pact-jvm/blob/master/pact-jvm-consumer/src/main/java/au/com/dius/pact/consumer/dsl/PactDslJsonBody.java#L580

1 ответ

Похоже, у вас есть несоответствие версий между версией библиотеки Pact, используемой в потребительском тесте, и версией, используемой для проверки поставщика.

Ваш потребительский тест использует V3 библиотеки pact (3.5.0-beta.2) и генерирует выражения соответствия V3 ($.totalTime).

Когда договор проверяется с провайдером, он ожидает выражения V2 ($.body.totalTime), а затем сопоставляется с использованием равенства, так как считает, что для этого атрибута нет соответствия.

Если в потребительском тесте вы вернетесь к версии 3.3.7, по умолчанию будет V2. Или вы можете принудительно установить V2 и по-прежнему использовать 3.5.0-бета.2, добавив в свой тестовый класс следующее:

@Override
protected PactSpecVersion getSpecificationVersion() {
    return PactSpecVersion.V2;
}
Другие вопросы по тегам