CEC-2579 Add ability to edit manifest (#226)

This commit is contained in:
arpanetus
2022-10-26 03:54:20 +06:00
committed by GitHub
parent aaf47f4cc7
commit 9a9766df12
11 changed files with 656 additions and 0 deletions

View File

@@ -43,6 +43,23 @@ export const ManifestsProvider = ({ children }) => {
return result;
};
const updateManifest = async (id, data, token) => {
validateManifestUpdate(data);
let result;
try {
setBusy(true);
result = await api.updateManifest(id, data, token);
if (result.error)
throw new Error(`Update manifest error. ${result.message}`);
} finally {
setBusy(false);
}
return result;
}
const deleteManifest = async (package_id, token) => {
let result;
@@ -69,6 +86,7 @@ export const ManifestsProvider = ({ children }) => {
busy,
manifests,
totalManifests,
updateManifest,
getManifest,
getManifests,
deleteManifest,
@@ -79,4 +97,14 @@ export const ManifestsProvider = ({ children }) => {
);
};
const validateManifestUpdate = (data) => {
if (data == null) throw new Error("No manifest data");
if (data.name == null || data.name.length>255) throw new Error("Invalid manifest name");
if (data.type == null || !["forced", "standard"].includes(data.type)) {
throw new Error("Invalid manifest type");
}
}
export const useManifestsContext = () => useContext(ManifestsContext);

View File

@@ -0,0 +1,109 @@
jest.mock("../../services/manifestsAPI");
import {
render,
cleanup,
screen,
fireEvent,
waitFor,
} from "@testing-library/react";
import { ManifestsProvider, useManifestsContext } from "./ManifestsContext";
import { StatusProvider, useStatusContext } from "./StatusContext";
const checkBaseResults = (error, busy) => {
expect(screen.getByTestId("error").innerHTML).toEqual(error);
expect(screen.getByTestId("busy").innerHTML).toEqual(busy);
};
describe("ManifestContext", () => {
describe("updateManifest", () => {
beforeEach(async () => {
const TestComp = () => {
const { busy, updateManifest } = useManifestsContext();
const { message, setMessage } = useStatusContext();
const update = async (data) => {
try {
await updateManifest(1, data);
} catch (e) {
setMessage(e.message);
}
};
return (
<>
<div data-testid="error">{message}</div>
<div data-testid="busy">{busy.toString()}</div>
<button
data-testid="updateManifestNull"
onClick={() => update(null)}
/>
<button
data-testid="updateManifestNoName"
onClick={() => update({type:"forced"})}
/>
<button
data-testid="updateManifestNoType"
onClick={() => update({name:"update"})}
/>
<button
data-testid="updateManifest"
onClick={() =>
update({
name: "new package",
type: "forced",
})
}
/>
</>
);
};
render(
<StatusProvider>
<ManifestsProvider>
<TestComp />
</ManifestsProvider>
</StatusProvider>
);
});
afterEach(() => {
cleanup();
});
it("initial state", () => {
checkBaseResults("", "false");
});
it("updateManifestNull", async () => {
fireEvent.click(screen.getByTestId("updateManifestNull"));
await waitFor(() =>
expect(screen.getByTestId("busy").innerHTML).toEqual("false")
);
checkBaseResults("No manifest data", "false");
});
it("updateManifestNoName", async () => {
fireEvent.click(screen.getByTestId("updateManifestNoName"));
await waitFor(() =>
expect(screen.getByTestId("busy").innerHTML).toEqual("false")
);
checkBaseResults("Invalid manifest name", "false");
});
it("updateManifestNoType", async () => {
fireEvent.click(screen.getByTestId("updateManifestNoType"));
await waitFor(() =>
expect(screen.getByTestId("busy").innerHTML).toEqual("false")
);
checkBaseResults("Invalid manifest type", "false");
});
it("updateManifest", async () => {
fireEvent.click(screen.getByTestId("updateManifest"));
await waitFor(() =>
expect(screen.getByTestId("busy").innerHTML).toEqual("false")
);
checkBaseResults("", "false");
});
});
});

View File

@@ -75,4 +75,5 @@ export const useManifestsContext = () => ({
getManifest: jest.fn(() => manifest),
getManifests: jest.fn(() => manifests),
deleteManifest: jest.fn(),
updateManifest: jest.fn(() => manifest),
});