mirror of
https://github.com/withastro/astro.git
synced 2025-01-20 22:12:38 -05:00
f5df12cfeb
* Provide guidance when --remote is omitted * Only restrict to server mode * Use an AstroError * Update code
201 lines
5.9 KiB
JavaScript
201 lines
5.9 KiB
JavaScript
import { expect } from 'chai';
|
|
import { load as cheerioLoad } from 'cheerio';
|
|
import testAdapter from '../../astro/test/test-adapter.js';
|
|
import { loadFixture } from '../../astro/test/test-utils.js';
|
|
import { setupRemoteDbServer } from './test-utils.js';
|
|
|
|
describe('astro:db', () => {
|
|
let fixture;
|
|
before(async () => {
|
|
fixture = await loadFixture({
|
|
root: new URL('./fixtures/basics/', import.meta.url),
|
|
output: 'server',
|
|
adapter: testAdapter(),
|
|
});
|
|
});
|
|
|
|
describe('development', () => {
|
|
let devServer;
|
|
|
|
before(async () => {
|
|
devServer = await fixture.startDevServer();
|
|
});
|
|
|
|
after(async () => {
|
|
await devServer.stop();
|
|
});
|
|
|
|
it('Prints the list of authors', async () => {
|
|
const html = await fixture.fetch('/').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
const ul = $('.authors-list');
|
|
expect(ul.children()).to.have.a.lengthOf(5);
|
|
expect(ul.children().eq(0).text()).to.equal('Ben');
|
|
});
|
|
|
|
it('Allows expression defaults for date columns', async () => {
|
|
const html = await fixture.fetch('/').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
const themeAdded = $($('.themes-list .theme-added')[0]).text();
|
|
expect(new Date(themeAdded).getTime()).to.not.be.NaN;
|
|
});
|
|
|
|
it('Defaults can be overridden for dates', async () => {
|
|
const html = await fixture.fetch('/').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
const themeAdded = $($('.themes-list .theme-added')[1]).text();
|
|
expect(new Date(themeAdded).getTime()).to.not.be.NaN;
|
|
});
|
|
|
|
it('Allows expression defaults for text columns', async () => {
|
|
const html = await fixture.fetch('/').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
const themeOwner = $($('.themes-list .theme-owner')[0]).text();
|
|
expect(themeOwner).to.equal('');
|
|
});
|
|
|
|
it('Allows expression defaults for boolean columns', async () => {
|
|
const html = await fixture.fetch('/').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
const themeDark = $($('.themes-list .theme-dark')[0]).text();
|
|
expect(themeDark).to.equal('dark mode');
|
|
});
|
|
|
|
it('text fields an be used as references', async () => {
|
|
const html = await fixture.fetch('/login').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
expect($('.session-id').text()).to.equal('12345');
|
|
expect($('.username').text()).to.equal('Mario');
|
|
});
|
|
|
|
it('Prints authors from raw sql call', async () => {
|
|
const json = await fixture.fetch('run.json').then((res) => res.json());
|
|
expect(json).to.deep.equal({
|
|
columns: ['_id', 'name', 'age2'],
|
|
columnTypes: ['INTEGER', 'TEXT', 'INTEGER'],
|
|
rows: [
|
|
[1, 'Ben', null],
|
|
[2, 'Nate', null],
|
|
[3, 'Erika', null],
|
|
[4, 'Bjorn', null],
|
|
[5, 'Sarah', null],
|
|
],
|
|
rowsAffected: 0,
|
|
lastInsertRowid: null,
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('development --remote', () => {
|
|
let devServer;
|
|
let remoteDbServer;
|
|
|
|
before(async () => {
|
|
remoteDbServer = await setupRemoteDbServer(fixture.config);
|
|
devServer = await fixture.startDevServer();
|
|
});
|
|
|
|
after(async () => {
|
|
await devServer?.stop();
|
|
await remoteDbServer?.stop();
|
|
});
|
|
|
|
it('Prints the list of authors', async () => {
|
|
const html = await fixture.fetch('/').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
const ul = $('.authors-list');
|
|
expect(ul.children()).to.have.a.lengthOf(5);
|
|
expect(ul.children().eq(0).text()).to.equal('Ben');
|
|
});
|
|
|
|
it('Allows expression defaults for date columns', async () => {
|
|
const html = await fixture.fetch('/').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
const themeAdded = $($('.themes-list .theme-added')[0]).text();
|
|
expect(new Date(themeAdded).getTime()).to.not.be.NaN;
|
|
});
|
|
|
|
it('Defaults can be overridden for dates', async () => {
|
|
const html = await fixture.fetch('/').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
const themeAdded = $($('.themes-list .theme-added')[1]).text();
|
|
expect(new Date(themeAdded).getTime()).to.not.be.NaN;
|
|
});
|
|
|
|
it('Allows expression defaults for text columns', async () => {
|
|
const html = await fixture.fetch('/').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
const themeOwner = $($('.themes-list .theme-owner')[0]).text();
|
|
expect(themeOwner).to.equal('');
|
|
});
|
|
|
|
it('Allows expression defaults for boolean columns', async () => {
|
|
const html = await fixture.fetch('/').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
const themeDark = $($('.themes-list .theme-dark')[0]).text();
|
|
expect(themeDark).to.equal('dark mode');
|
|
});
|
|
|
|
it('text fields an be used as references', async () => {
|
|
const html = await fixture.fetch('/login').then((res) => res.text());
|
|
const $ = cheerioLoad(html);
|
|
|
|
expect($('.session-id').text()).to.equal('12345');
|
|
expect($('.username').text()).to.equal('Mario');
|
|
});
|
|
|
|
it('Prints authors from raw sql call', async () => {
|
|
const json = await fixture.fetch('run.json').then((res) => res.json());
|
|
expect(json).to.deep.equal({
|
|
columns: ['_id', 'name', 'age2'],
|
|
columnTypes: ['INTEGER', 'TEXT', 'INTEGER'],
|
|
rows: [
|
|
[1, 'Ben', null],
|
|
[2, 'Nate', null],
|
|
[3, 'Erika', null],
|
|
[4, 'Bjorn', null],
|
|
[5, 'Sarah', null],
|
|
],
|
|
rowsAffected: 0,
|
|
lastInsertRowid: null,
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('build --remote', () => {
|
|
let remoteDbServer;
|
|
|
|
before(async () => {
|
|
process.env.ASTRO_STUDIO_APP_TOKEN = 'some token';
|
|
remoteDbServer = await setupRemoteDbServer(fixture.config);
|
|
await fixture.build();
|
|
});
|
|
|
|
after(async () => {
|
|
process.env.ASTRO_STUDIO_APP_TOKEN = '';
|
|
await remoteDbServer?.stop();
|
|
});
|
|
|
|
it('Can render page', async () => {
|
|
const app = await fixture.loadTestAdapterApp();
|
|
const request = new Request('http://example.com/');
|
|
const response = await app.render(request);
|
|
const html = await response.text();
|
|
const $ = cheerioLoad(html);
|
|
|
|
const ul = $('.authors-list');
|
|
expect(ul.children()).to.have.a.lengthOf(5);
|
|
});
|
|
});
|
|
});
|