@api-platform/client-generator
Version:
Generate apps built with Next, Nuxt, Quasar, React, React Native, Vue or Vuetify for any API documented using Hydra or OpenAPI
48 lines • 1.9 kB
JavaScript
import { Api, Resource, Field } from "@api-platform/api-doc-parser";
import path from "path";
import { fileURLToPath } from "url";
import fs from "fs";
import tmp from "tmp";
import NuxtGenerator from "./NuxtGenerator.js";
var dirname = path.dirname(fileURLToPath(import.meta.url));
var generator = new NuxtGenerator({
hydraPrefix: "hydra:",
templateDirectory: "".concat(dirname, "/../../templates")
});
afterEach(function () {
jest.resetAllMocks();
});
describe("generate", function () {
test("Generate a Nuxt app", function () {
var tmpobj = tmp.dirSync({
unsafeCleanup: true
});
var fields = [new Field("bar", {
id: "http://schema.org/url",
range: "http://www.w3.org/2001/XMLSchema#string",
reference: null,
required: true,
description: "An URL"
})];
var resource = new Resource("prefix/aBe_cd", "http://example.com/foos", {
id: "foo",
title: "Foo",
readableFields: fields,
writableFields: fields,
getParameters: function getParameters() {
return Promise.resolve([]);
}
});
var api = new Api("http://example.com", {
entrypoint: "http://example.com:8080",
title: "My API",
resources: [resource]
});
generator.generate(api, resource, tmpobj.name).then(function () {
["/components/foo/Form.vue", "/components/InputDate.vue", "/components/Loading.vue", "/components/Alert.vue", "/components/Toolbar.vue", "/config/entrypoint.js", "/error/SubmissionError.js", "/services/api.js", "/services/foo.js", "/store/foo.js", "/store/notifications.js", "/utils/dates.js", "/utils/fetch.js", "/utils/hydra.js", "/pages/foos/_id/edit.vue", "/pages/foos/_id/index.vue", "/pages/foos/index.vue", "/pages/foos/create.vue"].forEach(function (file) {
expect(fs.existsSync(tmpobj.name + file)).toBe(true);
});
tmpobj.removeCallback();
});
});
});