Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Migrating vitest to SDK #1672

Merged
merged 10 commits into from
Jan 27, 2024
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
11 changes: 7 additions & 4 deletions waspc/cli/src/Wasp/Cli/Command/Test.hs
Original file line number Diff line number Diff line change
Expand Up @@ -15,17 +15,20 @@ import Wasp.Cli.Command.Message (cliSendMessageC)
import Wasp.Cli.Command.Require (InWaspProject (InWaspProject), require)
import Wasp.Cli.Command.Watch (watch)
import qualified Wasp.Generator
import Wasp.Generator.Common (ProjectRootDir)
import qualified Wasp.Message as Msg
import Wasp.Project.Common (dotWaspDirInWaspProjectDir, generatedCodeDirInDotWaspDir)
import Wasp.Project.Common
( WaspProjectDir,
dotWaspDirInWaspProjectDir,
generatedCodeDirInDotWaspDir,
)

test :: [String] -> Command ()
test [] = throwError $ CommandError "Not enough arguments" "Expected: wasp test client <args>"
test ("client" : args) = watchAndTest $ Wasp.Generator.testWebApp args
test ("server" : _args) = throwError $ CommandError "Invalid arguments" "Server testing not yet implemented."
test _ = throwError $ CommandError "Invalid arguments" "Expected: wasp test client <args>"

watchAndTest :: (Path' Abs (Dir ProjectRootDir) -> IO (Either String ())) -> Command ()
watchAndTest :: (Path' Abs (Dir WaspProjectDir) -> IO (Either String ())) -> Command ()
watchAndTest testRunner = do
InWaspProject waspRoot <- require
let outDir = waspRoot </> dotWaspDirInWaspProjectDir </> generatedCodeDirInDotWaspDir
Expand All @@ -39,7 +42,7 @@ watchAndTest testRunner = do
watchOrStartResult <- liftIO $ do
ongoingCompilationResultMVar <- newMVar (warnings, [])
let watchWaspProjectSource = watch waspRoot outDir ongoingCompilationResultMVar
watchWaspProjectSource `race` testRunner outDir
watchWaspProjectSource `race` testRunner waspRoot
Copy link
Contributor Author

@infomiho infomiho Jan 25, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Instead of running from the .wasp/out dir, it now runs from the Wasp project root dir.


case watchOrStartResult of
Left () -> error "This should never happen, listening for file changes should never end but it did."
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,8 @@
import matchers from '@testing-library/jest-dom/matchers'
import { expect } from 'vitest'
import { afterEach } from 'vitest'
import { cleanup } from '@testing-library/react'
Copy link
Contributor Author

@infomiho infomiho Jan 24, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I've updated the vitest and all the accompanying libraries to the latest versions. I did this because there was an error with using jsx files from deps (in our case our SDK) which would mean we would need to bundle our SDK for vitest to work again.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Running with the latest versions seems to work fine 👍

import '@testing-library/jest-dom/vitest'

expect.extend(matchers)
// runs a clean after each test case (e.g. clearing jsdom)
afterEach(() => {
cleanup();
})
3 changes: 2 additions & 1 deletion waspc/data/Generator/templates/react-app/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,8 @@
"allowJs": true,
"strict": false,
// Allow importing pages with the .tsx extension.
"allowImportingTsExtensions": true
"allowImportingTsExtensions": true,
"types": ["@testing-library/jest-dom"]
},
"include": [
"src"
Expand Down
7 changes: 6 additions & 1 deletion waspc/data/Generator/templates/react-app/vite.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
/// <reference types="vitest" />
import { mergeConfig } from "vite";
import react from "@vitejs/plugin-react";
import { defaultExclude } from "vitest/config"

{=# customViteConfig.isDefined =}
// Ignoring the TS error because we are importing a file outside of TS root dir.
Expand Down Expand Up @@ -29,8 +30,12 @@ const defaultViteConfig = {
outDir: "build",
},
test: {
globals: true,
environment: "jsdom",
setupFiles: ["./src/test/vitest/setup.ts"],
setupFiles: ["./.wasp/out/web-app/src/test/vitest/setup.ts"],
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This file is already templated, so let's use the knowledge we have about this folder instead of hardcoding it.

// This is a hack to make Vite's test runner work with user files living
// outside of the web app root dir.
exclude: [...defaultExclude, ".wasp/**/*"]
Copy link
Contributor

@sodic sodic Jan 26, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same story as with setup files, .wasp is already defined somewhere in Haskell.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Good call, I've now changed the template 👍

},
// resolve: {
// dedupe: ["react", "react-dom"],
Expand Down
3 changes: 3 additions & 0 deletions waspc/data/Generator/templates/sdk/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,9 @@
{=! Used by users, documented. =}
"./dbSeed/types": "./dist/dbSeed/types.js",
{=! Used by users, documented. =}
"./test": "./dist/test/index.js",
{=! Used by our code, uncodumented (but accessible) for users. =}
"./test/*": "./dist/test/*.js",
"./crud/*": "./dist/crud/*.js",
{=! Used by our code, uncodumented (but accessible) for users. =}
"./server/crud/*": "./dist/server/crud/*",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { BrowserRouter as Router } from 'react-router-dom'
import { render, RenderResult, cleanup } from '@testing-library/react'
import { QueryClient, QueryClientProvider } from '@tanstack/react-query'
import { beforeAll, afterEach, afterAll } from 'vitest'
import { Query } from '../../queries'
import { Query } from 'wasp/rpc'
import config from 'wasp/core/config'
import { HttpMethod, Route } from 'wasp/types'

Expand Down
3 changes: 2 additions & 1 deletion waspc/data/Generator/templates/sdk/tsconfig.json
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,8 @@
"esModuleInterop": true,
"moduleResolution": "node",
"outDir": "dist",
"allowJs": true
"allowJs": true,
"types": ["@testing-library/jest-dom"],
Copy link
Contributor Author

@infomiho infomiho Jan 24, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There were type errors related to the unit test matchers e.g. toBeInTheDocument was reported as undefined. Since we are copying the ext-src to sdk we also need these types here.

// todo(filip): Only works with common js, see https://www.typescriptlang.org/tsconfig#paths and daily-article.
// "paths": {
// "@wasp/*": [
Expand Down
2 changes: 1 addition & 1 deletion waspc/examples/todo-typescript/.gitignore
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/.wasp/
/.env.server
/.env.client
/node_modules/
node_modules/
Copy link
Contributor Author

@infomiho infomiho Jan 24, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Vitest creates some cache files in the src dir and it does it in node_modules/.vitest

Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,8 @@
"./server/queries": "./dist/server/queries/index.js",
"./server/auth/email": "./dist/server/auth/email/index.js",
"./dbSeed/types": "./dist/dbSeed/types.js",
"./test": "./dist/test/index.js",
"./test/*": "./dist/test/*.js",
"./crud/*": "./dist/crud/*.js",
"./server/crud/*": "./dist/server/crud/*",
"./email": "./dist/email/index.js",
Expand Down
Loading
Loading