pact-js VS msw

Compare pact-js vs msw and see what are their differences.

pact-js

JS version of Pact. Pact is a contract testing framework for HTTP APIs and non-HTTP asynchronous messaging systems. (by pact-foundation)
Our great sponsors
  • SurveyJS - Open-Source JSON Form Builder to Create Dynamic Forms Right in Your App
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
pact-js msw
9 148
1,546 14,808
1.4% 2.3%
8.7 9.3
7 days ago 8 days ago
TypeScript TypeScript
GNU General Public License v3.0 or later MIT License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

pact-js

Posts with mentions or reviews of pact-js. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-12-22.
  • Enhancing Backend Microservices Ecosystem with Contract Testing [Spartans Summit 2024]
    1 project | dev.to | 16 Apr 2024
    First, he shows the official pact.io websites. Then, he clicks on the “View on Github” button by selecting Node JS and Javascript from the list of options.
  • Parsing AWS AppSync Responses, Elm GraphQL Libraries, and Only Doing Front-End
    3 projects | dev.to | 22 Dec 2023
    It just just enough abstraction over the basics of converting your HTTP calls to GraphQL queries and mutations, but ALL of the parsing of responses is on you. I’m well versed in parsing JSON in Elm. I’m also familiar with the compiler errors as well as runtime errors you get with JSON that doesn’t match up to what you designed. At some point I’ll probably have to move beyond the unit tests and add contact tests, maybe via Pact.js.
  • The Big TDD Misunderstanding
    1 project | news.ycombinator.com | 19 Nov 2023
    > I also wasn't aware that "unit" referred to an isolated test, not to the SUT.

    I'm with you. That claim is unsubstantiated. It seems to trace to the belief that the first unit tests were XUnit family, thus were SUnit for Scheme. But Kent Beck made it pretty clear that SUnit "units" were classes.

    https://web.archive.org/web/20150315073817/http://www.xprogr...

    There were unit tests before that. SUnit took its name from common parlance, not vice versa. It was a strange naming convention, given that the unit testing framework could be used to test anything and not just units. Much like the slightly older Test Anything Protocol (TAP) could.

    > [on unit tests] This does lead to a lot of work maintaining them whenever the implementation changes, but this is a necessary chore because of the value they provide.

    I disagree. Unit tests can still be behavioral. Then they change whenever the behavior changes. They should still work with a mere implementation change.

    > This is why I still think that the traditional test pyramid is the best model to follow.

    I'll disagree a little with that, too. I think a newer test pyramid that uses contract testing to verify integrations is better. The notion of contract tests is much newer than the pyramids and, properly applied, can speed up feedback by orders of magnitude while also cutting debugging time and maintenance by orders of magnitude.

    On that front, I love what Pact is doing and would like to see more competition in the area. Hottest thing in testing since Cypress/Playwright . . .

    https://pact.io

  • Ask HN: How do you test your microservices?
    1 project | news.ycombinator.com | 21 Jan 2023
    I've worked in places where Pact [0] was used for testing services developed by different teams (external) and teams themselves (internal)

    [0] https://pact.io/

  • A response to James Shore's Nullable pattern
    1 project | news.ycombinator.com | 16 Jan 2023
    I'd never heard anyone call those "integrity tests" before. I think "contract test" is more common.

    Assuming I understood you, that is.

    I've been telling everyone to look at Pact to make contract testing easier to organize and maintain and to make it easier to trigger in the other tests in CI when an interface's behavior changes. They haven't offered me a commission yet. ;-)

    https://pact.io

  • Gestionarea DTO-urilor intr-o arhitectura de tip Microservicii cu Event-Driven
    1 project | /r/programare | 15 Nov 2022
  • Can someone recommend technologies for testing automation for API application?
    2 projects | /r/softwaredevelopment | 11 Oct 2022
    We use pact and since introducing it we have significantly increased velocity and reduced test cycles as it catches things very early. For system tests we hand write them using whatever test frameworks the team is used to.
  • Advanced TypeScript Patterns: API Contracts
    3 projects | /r/javascript | 22 Aug 2022
    There is also Pact https://pact.io/ for a language agnostic pact testing.
  • Framework for end to end testing of microservices
    5 projects | /r/softwaretesting | 3 Jul 2022
    When you wish to focus on the contract ( which kind of field is required, ...), you shoud use contract testing frameworks. As you seem to leverage a microservices, a consumer driven contract testing approach with a framework like Pact.js is recommended.

msw

Posts with mentions or reviews of msw. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-25.
  • Easier TypeScript API Testing with Vitest + MSW
    3 projects | dev.to | 25 Apr 2024
    However, I discovered a great combination that transformed my API call testing in TypeScript: Vitest and Mock Service Worker (MSW). Their well-crafted design makes them incredibly easy to use, enhancing the overall testing experience.
  • Creating mocks for testing react code
    1 project | dev.to | 22 Apr 2024
    While mocks are effective, they require modifying the component's internal logic or mocking global functions like fetch. This can become cumbersome for complex components with numerous API interactions. Here's where MSW shines.
  • Storybook 8
    5 projects | news.ycombinator.com | 13 Mar 2024
    > For those wondering what the use case is, you must not have tried it. It does take work to set up (with each version that's less), but it can be very nice to test in isolation esp in cases where a component is under a login, the 4th page of a 10 page form, etc. Also obviously if you're working on a component library that ships without an app, Storybook can be your development and/or demo app.

    I have worked with storybook extensively over the past couple of years and my team is moving away from it in favour of MSW (https://mswjs.io).

    For "4th page of a 10 page form" during the development there's hot reloading which is really stable nowadays and haven't failed me, although I understand that some setups are old and it might be easier to configure Storybook than good hot reloading.

    I'm not entirely sure about the testing part of it and I'd be grateful if you could elaborate. I haven't felt the need for some special setup with SB because for unit tests, I can test a deeply nested component separately. For E2E tests, I usually test the whole form.

    I agree on the component library part, this is probably the only use case where Storybook is 100% justified, but I'm unconvinced about the

    6 projects | dev.to | 12 Mar 2024
    Additionally, thank you to all our community launch partners across the frontend ecosystem for helping us bring Storybook 8 to the world! Thanks to Chromatic, Figma, ViteConf, Omlet, DivRiots, story.to.design, StackBlitz, UXpin, Nx, Mock Service Worker, Anima, Zeplin, zeroheight, kickstartDS, and Kendo UI.
  • I made "TypeScript Swagger Editor", new type of Swagger UI writing TypeScript code in the browser
    3 projects | dev.to | 18 Feb 2024
    similar with msw.js, but fully automated
  • Partial: how not to mock the whole world
    4 projects | dev.to | 8 Feb 2024
    they could be network mocks (use msw)
  • How to Automatically Consume RESTful APIs in Your Frontend
    13 projects | dev.to | 25 Jan 2024
    With orval, we can also integrate the API client in our unit tests. Orval provides first class support for mocking through the (Mock Service Worker)[https://mswjs.io/] library, and it can automatically generate the MSW handlers for testing server.
  • Polly.js – Record, replay, and stub HTTP interactions
    2 projects | news.ycombinator.com | 8 Jan 2024
  • How to Successfully Integrate with Legacy APIs Using NodeJS
    2 projects | dev.to | 11 Dec 2023
    Consider a hypothetical scenario where data from a list of companies within an ERP needs to be retrieved. As a personal recommendation, leverage tools like MSW for top-level mocks, which can significantly enhance the testing process.
  • How do you manage Dependency Injection in Next.js APPS?
    1 project | /r/nextjs | 11 Dec 2023

What are some alternatives?

When comparing pact-js and msw you can also consider the following projects:

Nock - HTTP server mocking and expectations library for Node.js

Karate - Test Automation Made Simple

rtk-query - Data fetching and caching addon for Redux Toolkit

rust-wildbow-scraper - Automatically scrapes wildbow's web serials and compiles them into ebooks

miragejs - A client-side server to build, test and share your JavaScript app

zod - TypeScript-first schema validation with static type inference

mockoon - Mockoon is the easiest and quickest way to run mock APIs locally. No remote deployment, no account required, open source.

Robot Framework - Generic automation framework for acceptance testing and RPA

prism - Turn any OpenAPI2/3 and Postman Collection file into an API server with mocking, transformations and validations.

axios - Promise based HTTP client for the browser and node.js