mirror of
https://github.com/enso-org/enso.git
synced 2025-01-04 23:12:08 +03:00
3c31155fe9
- Implements https://github.com/enso-org/cloud-v2/issues/631 - Tests for dashboard (`app/ide-desktop/lib/dashboard/`): - End-to-end tests - Unit tests - Component tests The purpose of this PR is to introduce the testing framework - more tests can be added later in separate PRs. # Important Notes To test, run `npm run test` in `app/ide-desktop`, or `app/ide-desktop/lib/dashboard/`. All tests should pass. Individual test types can be run using `npm run test-unit`, `npm run test-component` and `npm run test-e2e` in `app/ide-desktop/lib/dashboard/`. Individual end-to-end tests can be run using `npx playwright test -c playwright-e2e.config.ts test-e2e/<file name>.spec.ts` in `app/ide-desktop/lib/dashboard/`. End-to-end tests require internet access to pass (for things like fonts). This PR *does* check in screenshots to guard against visual regessions (and/or to make visual changes obvious)
73 lines
2.4 KiB
TypeScript
73 lines
2.4 KiB
TypeScript
/** @file File watch and compile service. */
|
|
import * as module from 'node:module'
|
|
import * as path from 'node:path'
|
|
import * as url from 'node:url'
|
|
|
|
import * as esbuild from 'esbuild'
|
|
import chalk from 'chalk'
|
|
|
|
import * as bundler from './esbuild-config'
|
|
|
|
// =================
|
|
// === Constants ===
|
|
// =================
|
|
|
|
/** The path of this file. */
|
|
const THIS_PATH = path.resolve(path.dirname(url.fileURLToPath(import.meta.url)))
|
|
/** This must be port `8080` because it is defined as such in AWS. */
|
|
const PORT = 8080
|
|
const HTTP_STATUS_OK = 200
|
|
// `outputPath` does not have to be a real directory because `write` is `false`,
|
|
// meaning that files will not be written to the filesystem.
|
|
// However, the path should still be non-empty in order for `esbuild.serve` to work properly.
|
|
const OPTS = bundler.bundlerOptions({ outputPath: '/', devMode: process.env.DEV_MODE !== 'false' })
|
|
OPTS.define['REDIRECT_OVERRIDE'] = JSON.stringify(`http://localhost:${PORT}`)
|
|
OPTS.entryPoints.push(
|
|
path.resolve(THIS_PATH, 'src', 'index.html'),
|
|
path.resolve(THIS_PATH, 'src', 'index.tsx'),
|
|
path.resolve(THIS_PATH, 'src', 'serviceWorker.ts')
|
|
)
|
|
OPTS.minify = false
|
|
OPTS.write = false
|
|
OPTS.loader['.html'] = 'copy'
|
|
OPTS.pure.splice(OPTS.pure.indexOf('assert'), 1)
|
|
;(OPTS.inject = OPTS.inject ?? []).push(path.resolve(THIS_PATH, '..', '..', 'debugGlobals.ts'))
|
|
const REQUIRE = module.default.createRequire(import.meta.url)
|
|
OPTS.plugins.push({
|
|
name: 'react-dom-profiling',
|
|
setup: build => {
|
|
build.onResolve({ filter: /^react-dom$/ }, args => {
|
|
if (args.kind === 'import-statement') {
|
|
return { path: REQUIRE.resolve('react-dom/profiling') }
|
|
} else {
|
|
return
|
|
}
|
|
})
|
|
},
|
|
})
|
|
|
|
// ===============
|
|
// === Watcher ===
|
|
// ===============
|
|
|
|
/** Start the esbuild watcher. */
|
|
async function watch() {
|
|
const builder = await esbuild.context(OPTS)
|
|
await builder.watch()
|
|
await builder.serve({
|
|
port: PORT,
|
|
servedir: OPTS.outdir,
|
|
/** This function is called on every request.
|
|
* It is used here to show an error if the file to serve was not found. */
|
|
onRequest(args) {
|
|
if (args.status !== HTTP_STATUS_OK) {
|
|
console.error(
|
|
chalk.red(`HTTP error ${args.status} when serving path '${args.path}'.`)
|
|
)
|
|
}
|
|
},
|
|
})
|
|
}
|
|
|
|
void watch()
|