0
mswのモックをjestのテストでも使う
2022-08-19

開発用に定義したmswの設定をJestでも使いたい案件

参考のまんまだけどめちゃくちゃ簡単だった

テスト用のファイルに下記のように書くだけ

  • search.tsx
import { handlers } from "../../mocks/handler"
describe("Search", () => {
  const user = userEvent.setup()
  const server = setupServer(...handlers)

  beforeEach(() => {
    server.listen()
  })

  afterEach(() => {
    server.close()
  })

  it("検索UIのテスト", async () => {
    // mswでのモックレスポンスが適用される
    .....
    .....
    .....
    .....
  })
})
  • handler.ts
import { rest } from "msw"
import { setupServer } from "msw/node"

export const handlers = [
  rest.post("https://example.com/*", (req, res, ctx) => {
    return res(
      ctx.status(200),
      ctx.json({})
    )
  }),
]

setupServerで事前定義したhandlersを読ませbeforeEachで各テストの実行前にサーバ起動する

終わったら落とすようにしている

これだけでよい

とても楽

開発時とテスト時で同じ設定を使えるのもメンテナンス上とてもよい

外部へのリクエストが発生する機能はどんどん活用していくモチベーションが上がった

参考

0

Profile

swfz
swfz
日々学んだことを残していく
Today I Learned
コード片置き場

Account

RSS

Powered by Pixela
© 2025. swfz