feat: medusa-react admin hooks (#978)
* add: medusa admin hooks + tests * fix: remove unneeded props * fix: deps * fix: deps * fix: deps * fix: failing tests * fix: failing tests * fix: query key * add: yarn workspaces * fix: linting medusa-react * fix: add prepare script * fix: buildOptions * fix: useAdminShippingOptions query * fix: use qs instead for query params (#1019) * fix: formatting * debug: ci pipeline * debug: log node_modules structure * debug: use lerna bootstrap * debug: update node version * debug: print pkgs in workspace * debug: print pkgs in workspace * debug: print pkgs in workspace * debug: print pkgs in workspace * debug: add explicit build step * fix: jsdoc * debug: run build step * debug: fix build errors * debug: add build step to integration tests * fix: failing test * cleanup Co-authored-by: Sebastian Rindom <seb@medusajs.com> Co-authored-by: Sebastian Rindom <skrindom@gmail.com>
This commit is contained in:
@@ -0,0 +1,86 @@
|
||||
import {
|
||||
useAdminCreateNote,
|
||||
useAdminUpdateNote,
|
||||
useAdminDeleteNote,
|
||||
} from "../../../../src/"
|
||||
import { renderHook } from "@testing-library/react-hooks"
|
||||
import { fixtures } from "../../../../mocks/data"
|
||||
import { createWrapper } from "../../../utils"
|
||||
|
||||
describe("useAdminCreateNote hook", () => {
|
||||
test("creates a note and returns it", async () => {
|
||||
const note = {
|
||||
value: "talked to customer",
|
||||
resource_id: "test-swap",
|
||||
resource_type: "swap",
|
||||
}
|
||||
|
||||
const { result, waitFor } = renderHook(() => useAdminCreateNote(), {
|
||||
wrapper: createWrapper(),
|
||||
})
|
||||
|
||||
result.current.mutate(note)
|
||||
|
||||
await waitFor(() => result.current.isSuccess)
|
||||
|
||||
expect(result.current.data.response.status).toEqual(200)
|
||||
expect(result.current.data.note).toEqual(
|
||||
expect.objectContaining({
|
||||
...fixtures.get("note"),
|
||||
...note,
|
||||
})
|
||||
)
|
||||
})
|
||||
})
|
||||
|
||||
describe("useAdminUpdateNote hook", () => {
|
||||
test("updates a note and returns it", async () => {
|
||||
const note = {
|
||||
value: "problem with the supplier",
|
||||
resource_id: "test-return",
|
||||
resource_type: "return",
|
||||
}
|
||||
|
||||
const { result, waitFor } = renderHook(
|
||||
() => useAdminUpdateNote(fixtures.get("note").id),
|
||||
{
|
||||
wrapper: createWrapper(),
|
||||
}
|
||||
)
|
||||
|
||||
result.current.mutate(note)
|
||||
|
||||
await waitFor(() => result.current.isSuccess)
|
||||
|
||||
expect(result.current.data.response.status).toEqual(200)
|
||||
expect(result.current.data.note).toEqual(
|
||||
expect.objectContaining({
|
||||
...fixtures.get("note"),
|
||||
...note,
|
||||
})
|
||||
)
|
||||
})
|
||||
})
|
||||
|
||||
describe("useAdminDeleteNote hook", () => {
|
||||
test("deletes a note", async () => {
|
||||
const { result, waitFor } = renderHook(
|
||||
() => useAdminDeleteNote(fixtures.get("note").id),
|
||||
{
|
||||
wrapper: createWrapper(),
|
||||
}
|
||||
)
|
||||
|
||||
result.current.mutate()
|
||||
|
||||
await waitFor(() => result.current.isSuccess)
|
||||
|
||||
expect(result.current.data.response.status).toEqual(200)
|
||||
expect(result.current.data).toEqual(
|
||||
expect.objectContaining({
|
||||
id: fixtures.get("note").id,
|
||||
deleted: true,
|
||||
})
|
||||
)
|
||||
})
|
||||
})
|
||||
@@ -0,0 +1,32 @@
|
||||
import { useAdminNote, useAdminNotes } from "../../../../src"
|
||||
import { renderHook } from "@testing-library/react-hooks"
|
||||
import { fixtures } from "../../../../mocks/data"
|
||||
import { createWrapper } from "../../../utils"
|
||||
|
||||
describe("useAdminNotes hook", () => {
|
||||
test("returns a list of notes", async () => {
|
||||
const notes = fixtures.list("note")
|
||||
const { result, waitFor } = renderHook(() => useAdminNotes(), {
|
||||
wrapper: createWrapper(),
|
||||
})
|
||||
|
||||
await waitFor(() => result.current.isSuccess)
|
||||
|
||||
expect(result.current.response.status).toEqual(200)
|
||||
expect(result.current.notes).toEqual(notes)
|
||||
})
|
||||
})
|
||||
|
||||
describe("useAdminNote hook", () => {
|
||||
test("returns a note", async () => {
|
||||
const note = fixtures.get("note")
|
||||
const { result, waitFor } = renderHook(() => useAdminNote(note.id), {
|
||||
wrapper: createWrapper(),
|
||||
})
|
||||
|
||||
await waitFor(() => result.current.isSuccess)
|
||||
|
||||
expect(result.current.response.status).toEqual(200)
|
||||
expect(result.current.note).toEqual(note)
|
||||
})
|
||||
})
|
||||
Reference in New Issue
Block a user