diff --git a/.eslintignore b/.eslintignore index 569b8e3ba..e26596181 100644 --- a/.eslintignore +++ b/.eslintignore @@ -28,8 +28,8 @@ /tests/vite-app/ /packages/vite/index.mjs /packages/vite/index.d.ts -/packages/vite/src/**/*.js -/packages/vite/src/**/*.d.ts +/packages/vite/**/*.js +/packages/vite/**/*.d.ts # unconventional js diff --git a/.prettierignore b/.prettierignore index 685ae88e3..cac4a26a7 100644 --- a/.prettierignore +++ b/.prettierignore @@ -1,5 +1,5 @@ # No need to run prettier here -*.md +*.md *.yml *.yaml *.html @@ -35,10 +35,8 @@ /packages/addon-dev/**/*.d.ts /tests/fixtures/ /packages/vite/index.mjs -/packages/vite/index.d.ts -/packages/vite/src/**/*.js -/packages/vite/src/**/*.d.ts - +/packages/vite/**/*.js +/packages/vite/**/*.d.ts # unconventional js /blueprints/*/files/ diff --git a/packages/vite/.gitignore b/packages/vite/.gitignore index 68c2b31d0..ee7918ebe 100644 --- a/packages/vite/.gitignore +++ b/packages/vite/.gitignore @@ -2,6 +2,6 @@ /src/**/*.js /src/**/*.d.ts /src/**/*.map -/*/tests/**/*.js -/*/tests/**/*.d.ts -/*/tests/**/*.map +/tests/**/*.js +/tests/**/*.d.ts +/tests/**/*.map diff --git a/packages/vite/index.d.ts b/packages/vite/index.d.ts index f0ebe93c4..550edc816 100644 --- a/packages/vite/index.d.ts +++ b/packages/vite/index.d.ts @@ -2,4 +2,5 @@ export * from './src/resolver.js'; export * from './src/hbs.js'; export * from './src/scripts.js'; export * from './src/template-tag.js'; -export * from './src/addons.js'; \ No newline at end of file +export * from './src/addons.js'; +export * from './src/optimize-deps.js'; diff --git a/packages/vite/index.mjs b/packages/vite/index.mjs index f0ebe93c4..550edc816 100644 --- a/packages/vite/index.mjs +++ b/packages/vite/index.mjs @@ -2,4 +2,5 @@ export * from './src/resolver.js'; export * from './src/hbs.js'; export * from './src/scripts.js'; export * from './src/template-tag.js'; -export * from './src/addons.js'; \ No newline at end of file +export * from './src/addons.js'; +export * from './src/optimize-deps.js'; diff --git a/packages/vite/jest.config.js b/packages/vite/jest.config.js new file mode 100644 index 000000000..cdaa1f960 --- /dev/null +++ b/packages/vite/jest.config.js @@ -0,0 +1,4 @@ +module.exports = { + testEnvironment: 'node', + testMatch: ['/tests/**/*.test.js'], +}; diff --git a/packages/vite/package.json b/packages/vite/package.json index 40acd0b0e..b6bb43c0c 100644 --- a/packages/vite/package.json +++ b/packages/vite/package.json @@ -6,6 +6,9 @@ "@embroider/core": "workspace:^", "vite": "^4.3.9" }, + "scripts": { + "test": "jest" + }, "dependencies": { "@rollup/pluginutils": "^4.1.1", "assert-never": "^1.2.1", diff --git a/packages/vite/src/optimize-deps.ts b/packages/vite/src/optimize-deps.ts new file mode 100644 index 000000000..91cb6cc16 --- /dev/null +++ b/packages/vite/src/optimize-deps.ts @@ -0,0 +1,10 @@ +export interface OptimizeDeps { + exclude?: string[]; + [key: string]: unknown; +} + +export function optimizeDeps(): OptimizeDeps { + return { + exclude: ['@embroider/macros'], + }; +} diff --git a/packages/vite/tests/optimize-deps.test.ts b/packages/vite/tests/optimize-deps.test.ts new file mode 100644 index 000000000..a43c3c516 --- /dev/null +++ b/packages/vite/tests/optimize-deps.test.ts @@ -0,0 +1,13 @@ +import { optimizeDeps } from '../src/optimize-deps'; + +describe('optimizeDeps', function () { + test('should produce default output when invoked without arguments', function () { + const actual = optimizeDeps(); + + const expected = { + exclude: ['@embroider/macros'], + }; + + expect(actual).toEqual(expected); + }); +}); diff --git a/tests/vite-app/vite.config.mts b/tests/vite-app/vite.config.mts index e61ae1094..dd5985900 100644 --- a/tests/vite-app/vite.config.mts +++ b/tests/vite-app/vite.config.mts @@ -1,5 +1,12 @@ import { defineConfig } from "vite"; -import { resolver, hbs, scripts, templateTag, addons } from "@embroider/vite"; +import { + resolver, + hbs, + scripts, + templateTag, + addons, + optimizeDeps, +} from "@embroider/vite"; import { resolve } from "path"; import { babel } from "@rollup/plugin-babel"; @@ -23,9 +30,7 @@ export default defineConfig({ extensions: [".gjs", ".js", ".hbs"], }), ], - optimizeDeps: { - exclude: addons(__dirname), - }, + optimizeDeps: optimizeDeps(), server: { watch: { ignored: ["!**/node_modules/.embroider/rewritten-app/**"],