Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: add compile option to enable rerun of transpilation for react templates #1177

Merged
merged 45 commits into from
Aug 26, 2024
Merged
Show file tree
Hide file tree
Changes from 27 commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
bbe0a7b
added a compile option to enable skipping default transpilation
Gmin2 Apr 4, 2024
565eefb
updated jsdoc and implemented conditional transpilation in configureT…
Gmin2 Apr 9, 2024
cb0ca24
added some changes
Gmin2 Apr 10, 2024
ef94410
added integration testing for compile flag
Gmin2 May 18, 2024
492814e
added a compile option to enable skipping default transpilation
Gmin2 Apr 4, 2024
77cc9d1
updated jsdoc and implemented conditional transpilation in configureT…
Gmin2 Apr 9, 2024
d5c986c
rebased:added some changes
Gmin2 Apr 10, 2024
237b14a
remove integration test
Gmin2 Jun 29, 2024
830d195
fixed linting problem
Gmin2 Jun 29, 2024
13aea56
added console logs in configureReact and added test
Gmin2 Jul 1, 2024
792fc3c
added the integration test and cleanup
Gmin2 Jul 10, 2024
1dbf3db
remove the unit test
Gmin2 Jul 10, 2024
b4037f4
remove temp.md
Gmin2 Jul 10, 2024
cee60c2
added integration test to be created during the testing
Gmin2 Jul 10, 2024
d4589aa
cleanup
Gmin2 Jul 10, 2024
0407e86
updated the test
Gmin2 Jul 22, 2024
d3f1ba9
make the reviewed changes
Gmin2 Jul 24, 2024
ebbf27e
fixed linting prob
Gmin2 Jul 24, 2024
39169e0
removed the `__transpiled` folder content for cleanup of test
Gmin2 Jul 31, 2024
0245b65
renamed the corrected name
Gmin2 Jul 31, 2024
b3df084
Merge branch 'master' into compile
derberg Jul 31, 2024
cd52244
Merge remote-tracking branch 'upstream/master' into compile
Gmin2 Aug 4, 2024
d31e67b
fixed conflicts
Gmin2 Aug 4, 2024
b864bd1
Merge branch 'compile' of https://github.com/utnim2/generator into co…
Gmin2 Aug 4, 2024
65ee591
fixed conflict
Gmin2 Aug 4, 2024
c7323d9
removedd the catch block
Gmin2 Aug 4, 2024
5bd97e1
Merge remote-tracking branch 'upstream/master' into compile
Gmin2 Aug 13, 2024
da7cc75
Merge branch 'master' into compile
derberg Aug 19, 2024
2f6e74f
tests: update tests
derberg Aug 20, 2024
04522a5
Merge pull request #1 from derberg/compile
Gmin2 Aug 21, 2024
8e5b6d0
Merge branch 'compile' of https://github.com/utnim2/generator into co…
Gmin2 Aug 21, 2024
cc0bf09
Merge branch 'master' into compile
derberg Aug 21, 2024
7627f56
Update package-lock.json
derberg Aug 21, 2024
f37b920
Merge remote-tracking branch 'upstream/master' into compile
Gmin2 Aug 21, 2024
f817b42
removed `compile` from cli.js and fixed double import
Gmin2 Aug 21, 2024
9dbb7b7
Merge remote-tracking branch 'origin/compile' into compile
Gmin2 Aug 21, 2024
d98a38d
added the changeset for the release
Gmin2 Aug 21, 2024
5e9efbe
Update cli.js
derberg Aug 21, 2024
8082c8e
Update package-lock.json
derberg Aug 21, 2024
7f2af96
Update test-project.test.js
derberg Aug 21, 2024
6e5cc87
Update test-registry.test.js
derberg Aug 21, 2024
cfda26f
making the compile option by default true
Gmin2 Aug 26, 2024
7123a04
Merge branch 'compile' of https://github.com/utnim2/generator into co…
Gmin2 Aug 26, 2024
7b3c1a9
a small test change
Gmin2 Aug 26, 2024
834b3cc
Update compile_option.md
derberg Aug 26, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions apps/generator/cli.js
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,7 @@ program
})
.option('-d, --disable-hook [hooks...]', 'disable a specific hook type or hooks from given hook type', disableHooksParser)
.option('--debug', 'enable more specific errors in the console')
.option('--compile', 'compile the template files before rendering')
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

after all works remember to remove compile flag from here as we do not enable new flags in local cli

.option('-i, --install', 'installs the template and its dependencies (defaults to false)')
.option('-n, --no-overwrite <glob>', 'glob or path of the file(s) to skip when regenerating', noOverwriteParser)
.option('-o, --output <outputDir>', 'directory where to put the generated files (defaults to current directory)', parseOutput, process.cwd())
Expand Down Expand Up @@ -150,6 +151,7 @@ function generate(targetDir) {
forceWrite: program.forceWrite,
install: program.install,
debug: program.debug,
compile: program.compile,
mapBaseUrlToFolder
});

Expand Down
10 changes: 6 additions & 4 deletions apps/generator/lib/generator.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ const DEFAULT_TEMPLATES_DIR = path.resolve(ROOT_DIR, 'node_modules');

const TRANSPILED_TEMPLATE_LOCATION = '__transpiled';
const TEMPLATE_CONTENT_DIRNAME = 'template';
const GENERATOR_OPTIONS = ['debug', 'disabledHooks', 'entrypoint', 'forceWrite', 'install', 'noOverwriteGlobs', 'output', 'templateParams', 'mapBaseUrlToFolder', 'url', 'auth', 'token', 'registry'];
const GENERATOR_OPTIONS = ['debug', 'disabledHooks', 'entrypoint', 'forceWrite', 'install', 'noOverwriteGlobs', 'output', 'templateParams', 'mapBaseUrlToFolder', 'url', 'auth', 'token', 'registry', 'compile'];
const logMessage = require('./logMessages');

const shouldIgnoreFile = filePath =>
Expand Down Expand Up @@ -86,20 +86,22 @@ class Generator {
* @param {Boolean} [options.forceWrite=false] Force writing of the generated files to given directory even if it is a git repo with unstaged files or not empty dir. Default is set to false.
* @param {Boolean} [options.install=false] Install the template and its dependencies, even when the template has already been installed.
* @param {Boolean} [options.debug=false] Enable more specific errors in the console. At the moment it only shows specific errors about filters. Keep in mind that as a result errors about template are less descriptive.
* @param {Boolean} [options.compile=false] Whether to compile the template or use the cached transpiled version provided by template in '__transpiled' folder
* @param {Object<String, String>} [options.mapBaseUrlToFolder] Optional parameter to map schema references from a base url to a local base folder e.g. url=https://schema.example.com/crm/ folder=./test/docs/ .
* @param {Object} [options.registry] Optional parameter with private registry configuration
* @param {String} [options.registry.url] Parameter to pass npm registry url
* @param {String} [options.registry.auth] Optional parameter to pass npm registry username and password encoded with base64, formatted like username:password value should be encoded
* @param {String} [options.registry.token] Optional parameter to pass npm registry auth token that you can grab from .npmrc file
*/

constructor(templateName, targetDir, { templateParams = {}, entrypoint, noOverwriteGlobs, disabledHooks, output = 'fs', forceWrite = false, install = false, debug = false, mapBaseUrlToFolder = {}, registry = {}} = {}) {
constructor(templateName, targetDir, { templateParams = {}, entrypoint, noOverwriteGlobs, disabledHooks, output = 'fs', forceWrite = false, install = false, debug = false, mapBaseUrlToFolder = {}, registry = {}, compile = false } = {}) {
const options = arguments[arguments.length - 1];
this.verifyoptions(options);
if (!templateName) throw new Error('No template name has been specified.');
if (!entrypoint && !targetDir) throw new Error('No target directory has been specified.');
if (!['fs', 'string'].includes(output)) throw new Error(`Invalid output type ${output}. Valid values are 'fs' and 'string'.`);

/** @type {Boolean} Whether to compile the template or use the cached transpiled version provided by template in '__transpiled' folder. */
this.compile = compile;
/** @type {Object} Npm registry information. */
this.registry = registry;
/** @type {String} Name of the template to generate. */
Expand Down Expand Up @@ -393,7 +395,7 @@ class Generator {
* Configure the templates based the desired renderer.
*/
async configureTemplate() {
if (isReactTemplate(this.templateConfig)) {
if (isReactTemplate(this.templateConfig) && this.compile) {
await configureReact(this.templateDir, this.templateContentDir, TRANSPILED_TEMPLATE_LOCATION);
} else {
this.nunjucks = configureNunjucks(this.debug, this.templateDir);
Expand Down
6 changes: 6 additions & 0 deletions apps/generator/lib/logMessages.js
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,10 @@ function conditionalFilesMatched(relativeSourceFile) {
return `${relativeSourceFile} was not generated because condition specified for this file in template configuration in conditionalFiles matched.`;
}

function compileEnabled(dir, output_dir) {
return `Transpilation of files ${dir} into ${output_dir} started.`;
}

module.exports = {
TEMPLATE_INSTALL_FLAG_MSG,
TEMPLATE_INSTALL_DISK_MSG,
Expand All @@ -59,5 +63,7 @@ module.exports = {
templateSuccessfullyInstalled,
relativeSourceFileNotGenerated,
conditionalFilesMatched,
compileEnabled,
compileEnabled,
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

doubled export

skipOverwrite
};
2 changes: 2 additions & 0 deletions apps/generator/lib/renderer/react.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,11 @@ const reactExport = module.exports;
* @param {string} templateLocation located for thetemplate
* @param {string} templateContentDir where the template content are located
* @param {string} transpiledTemplateLocation folder for the transpiled code
* @param {Boolean} compile Whether to compile the template files or used the cached transpiled version provided by the template in the '__transpiled' folder
*/
reactExport.configureReact = async (templateLocation, templateContentDir, transpiledTemplateLocation) => {
const outputDir = path.resolve(templateLocation, `./${transpiledTemplateLocation}`);
log.debug(logMessage.compileEnabled(templateContentDir, outputDir));
await AsyncReactSDK.transpileFiles(templateContentDir, outputDir, {
recursive: true
});
Expand Down
3 changes: 3 additions & 0 deletions apps/generator/test/generator.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ describe('Generator', () => {
expect(gen.forceWrite).toStrictEqual(false);
expect(gen.install).toStrictEqual(false);
expect(gen.templateParams).toStrictEqual({});
expect(gen.compile).toStrictEqual(false);
});

it('works with all the params', () => {
Expand All @@ -39,6 +40,7 @@ describe('Generator', () => {
templateParams: {
test: true,
},
compile: true,
});
expect(gen.templateName).toStrictEqual('testTemplate');
expect(gen.targetDir).toStrictEqual(__dirname);
Expand All @@ -48,6 +50,7 @@ describe('Generator', () => {
expect(gen.output).toStrictEqual('string');
expect(gen.forceWrite).toStrictEqual(true);
expect(gen.install).toStrictEqual(true);
expect(gen.compile).toStrictEqual(true);
expect(() => gen.templateParams.test).toThrow('Template parameter "test" has not been defined in the package.json file under generator property. Please make sure it\'s listed there before you use it in your template.');

// Mock params on templateConfig so it doesn't fail.
Expand Down
62 changes: 60 additions & 2 deletions apps/generator/test/integration.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@
* @jest-environment node
*/

const { mkdir, writeFile, readFile } = require('fs').promises;
const path = require('path');
const { readFile, writeFile, access, unlink, mkdir } = require('fs').promises;
const Generator = require('../lib/generator');
const dummySpecPath = path.resolve(__dirname, './docs/dummy.yml');
const refSpecPath = path.resolve(__dirname, './docs/apiwithref.json');
Expand All @@ -19,9 +19,21 @@ describe('Integration testing generateFromFile() to make sure the result of the
return path.resolve(mainTestResultPath, crypto.randomBytes(4).toString('hex'));
};

jest.setTimeout(60000);
jest.setTimeout(100000);
const testOutputFile = 'test-file.md';

const tempJsContent = `
import { File, Text } from '@asyncapi/generator-react-sdk';

export default function() {
return (
<File name="temp.md">
<Text>Test</Text>
</File>
);
}
`;

it('generated using Nunjucks template', async () => {
const outputDir = generateFolderName();
const generator = new Generator(nunjucksTemplate, outputDir, {
Expand Down Expand Up @@ -56,6 +68,52 @@ describe('Integration testing generateFromFile() to make sure the result of the
expect(file).toMatchSnapshot();
});

it('check if the temp.md file is created with compile option true', async () => {
const outputDir = generateFolderName();

// Create temp.md.js file dynamically
const tempJsPath = path.join(reactTemplate, 'template/temp.md.js');
await writeFile(tempJsPath, tempJsContent);

const generator = new Generator(reactTemplate, outputDir, {
forceWrite: true,
compile: true,
debug: true,
});
await generator.generateFromFile(dummySpecPath);

const tempMdPath = path.join(outputDir, 'temp.md');

// Check the content of temp.md
const tempMdContent = await readFile(tempMdPath, 'utf8');
expect(tempMdContent.trim()).toBe('Test');
});

it('check if the temp.md file is not created when compile option is false', async () => {
const outputDir = generateFolderName();

// first we need to do cleanup of the react template `__transpiled` folder as from previous test it will have the transpiled files
const transpiledPath = path.join(reactTemplate, '__transpiled');
await unlink(path.join(transpiledPath, 'temp.md.js'));
await unlink(path.join(transpiledPath, 'temp.md.js.map'));

// Create temp.md.js file dynamically
const tempJsPath = path.join(reactTemplate, 'template/temp.md.js');
await writeFile(tempJsPath, tempJsContent);

const generator = new Generator(reactTemplate, outputDir, {
forceWrite: true,
compile: false,
debug: true
});
await generator.generateFromFile(dummySpecPath);

// Check if temp.md is not created in the output directory
const tempMdPath = path.join(outputDir, 'temp.md');
const tempMdExists = await access(tempMdPath).then(() => true).catch(() => false);
expect(tempMdExists).toBe(false);
});

it('should ignore specified files with noOverwriteGlobs', async () => {
const outputDir = generateFolderName();
// Manually create a file to test if it's not overwritten
Expand Down
Loading