* refactor: new version of create-astro * chore: update README * fix(create-astro): update project name logic * test(create-astro): fix test on windows * test(create-astro): fix test on windows * test(create-astro): remove unused import * chore: remove log * chore: increase test timeout * fix: message when skipping * fix: message for env.d.ts file * fix: always hard exit * fix: return from next-steps * chore: add message * refactor dependencies, bundle create-astro * chore: disable create-astro typings * chore: switch to arg * chore: update message * fix: split typescript into two steps, fix context test * chore: update wording * chore: update wording * Update packages/create-astro/src/actions/dependencies.ts Co-authored-by: Yan Thomas <61414485+Yan-Thomas@users.noreply.github.com> * refactor: move tests back to mocha/chai * chore: update cli-kit * update test script * chore: add comment about setStdout * chore: update cli-kit * Update packages/create-astro/src/messages.ts Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca> * Update packages/create-astro/src/messages.ts Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca> * chore: update lockfile * fix(create-astro): support scoped package names, improve project-name tests * better git initialization * update cli-kit --------- Co-authored-by: Nate Moore <nate@astro.build> Co-authored-by: Yan Thomas <61414485+Yan-Thomas@users.noreply.github.com> Co-authored-by: Sarah Rainsberger <sarah@rainsberger.ca>
42 lines
1.6 KiB
JavaScript
42 lines
1.6 KiB
JavaScript
import { expect } from 'chai';
|
|
|
|
import { dependencies } from '../dist/index.js';
|
|
import { setup } from './utils.js';
|
|
|
|
describe('dependencies', () => {
|
|
const fixture = setup();
|
|
|
|
it('--yes', async () => {
|
|
const context = { cwd: '', yes: true, pkgManager: 'npm', dryRun: true, prompt: (() => ({ deps: true }))};
|
|
await dependencies(context);
|
|
expect(fixture.hasMessage('Skipping dependency installation')).to.be.true;
|
|
})
|
|
|
|
it('prompt yes', async () => {
|
|
const context = { cwd: '', pkgManager: 'npm', dryRun: true, prompt: (() => ({ deps: true })), install: undefined };
|
|
await dependencies(context);
|
|
expect(fixture.hasMessage('Skipping dependency installation')).to.be.true;
|
|
expect(context.install).to.eq(true);
|
|
})
|
|
|
|
it('prompt no', async () => {
|
|
const context = { cwd: '', pkgManager: 'npm', dryRun: true, prompt: (() => ({ deps: false })), install: undefined };
|
|
await dependencies(context);
|
|
expect(fixture.hasMessage('Skipping dependency installation')).to.be.true;
|
|
expect(context.install).to.eq(false);
|
|
})
|
|
|
|
it('--install', async () => {
|
|
const context = { cwd: '', install: true, pkgManager: 'npm', dryRun: true, prompt: (() => ({ deps: false })) };
|
|
await dependencies(context);
|
|
expect(fixture.hasMessage('Skipping dependency installation')).to.be.true;
|
|
expect(context.install).to.eq(true);
|
|
})
|
|
|
|
it('--no-install', async () => {
|
|
const context = { cwd: '', install: false, pkgManager: 'npm', dryRun: true, prompt: (() => ({ deps: false })) };
|
|
await dependencies(context);
|
|
expect(fixture.hasMessage('Skipping dependency installation')).to.be.true;
|
|
expect(context.install).to.eq(false);
|
|
})
|
|
})
|