Skip to content

Commit

Permalink
Add an integration test, which accesses the KG rather than using mock…
Browse files Browse the repository at this point in the history
… data.
  • Loading branch information
apdavison committed Aug 8, 2024
1 parent dc8bd38 commit f9c1ec6
Show file tree
Hide file tree
Showing 8 changed files with 56 additions and 5 deletions.
11 changes: 11 additions & 0 deletions .gitlab-ci.yml
Original file line number Diff line number Diff line change
@@ -1,6 +1,17 @@
stages:
- test
- build

test_app:
stage: test
script:
- cd apps/nar-v3
- npm ci
- npm run testci # runs all tests whose name does _not_ contain "KG"
tags:
- docker-runner
image: docker-registry.ebrains.eu/neuralactivity/node:20-alpine

build_image_production:
stage: build
only:
Expand Down
3 changes: 3 additions & 0 deletions apps/nar-v3/__tests__/globals.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
const authToken = null; // for local testing, provide an EBRAINS IAM token

export { authToken };
27 changes: 27 additions & 0 deletions apps/nar-v3/__tests__/routes/home.test.jsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import { describe, test, expect } from "vitest";
import { render, screen } from "@testing-library/react";
import App from "../../src/main";
import { authToken } from "../globals";

describe("test with real KG queries", () => {
// this test requires a valid auth token to have been set in globals.js,
// since it actually makes KG queries
test("check home route with KG", { timeout: 10000 }, async () => {
const auth = {
token: authToken,
};
render(<App auth={auth} />);

expect(screen.getByText("EBRAINS: Neural Activity Resource (alpha)")).toBeDefined();

const label = await screen.findByText("Patch clamp recording", {}, { timeout: 10000 });
expect(label).toBeDefined();

const datasetCountChip = await screen.findByTitle(
"All neural activity datasets count",
{},
{ timeout: 10000 }
);
expect(parseInt(datasetCountChip.textContent)).toBeGreaterThan(0);
});
});
2 changes: 1 addition & 1 deletion apps/nar-v3/__tests__/setup.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,5 @@ import { vi } from "vitest";

const fetchMocker = createFetchMock(vi);

// sets globalThis.fetch and globalThis.fetchMock to our mocked version
fetchMocker.enableMocks();
fetchMocker.dontMock();
2 changes: 1 addition & 1 deletion apps/nar-v3/__tests__/utility.test.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { expect, test } from "vitest";
import { getKGSearchUrl } from "../src/utility";

test("generates KG Search URL as expected", () => {
test("generates EBRAINS Search URL as expected", () => {
expect(
getKGSearchUrl("https://kg.ebrains.eu/api/instances/2843990a-69dd-468b-a1d3-ff9589b485ae")
).toBe("https://search.kg.ebrains.eu/instances/2843990a-69dd-468b-a1d3-ff9589b485ae");
Expand Down
1 change: 1 addition & 0 deletions apps/nar-v3/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@
"lint": "eslint src --ext js,jsx --report-unused-disable-directives --max-warnings 0",
"preview": "vite preview",
"test": "vitest",
"testci": "vitest -t '^((?!KG).)*$'",
"coverage": "vitest run --coverage"
},
"dependencies": {
Expand Down
13 changes: 11 additions & 2 deletions apps/nar-v3/src/main.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -88,8 +88,10 @@ function getRouter(auth) {
]);
}

function renderApp(auth) {
ReactDOM.createRoot(document.getElementById("root")).render(
export default function App(props) {
const auth = props.auth;

return (
<React.StrictMode>
<ThemeProvider theme={theme}>
<CssBaseline />
Expand All @@ -113,6 +115,13 @@ function renderApp(auth) {
</main>
</ThemeProvider>
</React.StrictMode>
)

}

function renderApp(auth) {
ReactDOM.createRoot(document.getElementById("root")).render(
<App auth={auth} />
);
}

Expand Down
2 changes: 1 addition & 1 deletion apps/nar-v3/src/routes/home.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ function ModalityCard(props) {
<CardMedia component="img" height="200" image={image} title={label} />
<CardContent>
<Typography gutterBottom variant="h5" component="h2">
{label} <Chip label={count} />
{label} <Chip label={count} title={`${label} count`} />
</Typography>
</CardContent>
</CardActionArea>
Expand Down

0 comments on commit f9c1ec6

Please sign in to comment.