Skip to content

Commit

Permalink
Merge branch 'master' into additional-properties
Browse files Browse the repository at this point in the history
  • Loading branch information
mrlubos authored Feb 2, 2024
2 parents 7ebe284 + 20dac04 commit 7a3c689
Show file tree
Hide file tree
Showing 10 changed files with 68 additions and 31 deletions.
2 changes: 2 additions & 0 deletions bin/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ const params = program
.option('--name <value>', 'Custom client class name')
.option('--useOptions', 'Use options instead of arguments')
.option('--useUnionTypes', 'Use union types instead of enums')
.option('--autoformat <value>', 'Process generated files with autoformatter', false)
.option('--exportCore <value>', 'Write core files to disk', true)
.option('--exportServices <value>', 'Write services to disk', true)
.option('--exportModels <value>', 'Write models to disk', true)
Expand Down Expand Up @@ -45,6 +46,7 @@ if (OpenAPI) {
clientName: params.name,
useOptions: params.useOptions,
useUnionTypes: params.useUnionTypes,
autoformat: JSON.parse(params.autoformat) === true,
exportCore: JSON.parse(params.exportCore) === true,
exportServices: parseBooleanOrString(params.exportServices),
exportModels: parseBooleanOrString(params.exportModels),
Expand Down
14 changes: 14 additions & 0 deletions bin/index.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,20 @@ describe('bin', () => {
expect(result.stderr.toString()).toBe('');
});

it('should autoformat with Prettier', async () => {
const result = crossSpawn.sync('node', [
'./bin/index.js',
'--input',
'./test/spec/v3.json',
'--output',
'./test/generated/bin',
'--autoformat',
'true',
]);
expect(result.stdout.toString()).toBe('');
expect(result.stderr.toString()).toBe('');
});

it('it should throw error without params', async () => {
const result = crossSpawn.sync('node', ['./bin/index.js']);
expect(result.stdout.toString()).toBe('');
Expand Down
54 changes: 27 additions & 27 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 4 additions & 4 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@nicolas-chaulet/openapi-typescript-codegen",
"version": "0.27.3",
"version": "0.27.4",
"description": "Library that generates Typescript clients based on the OpenAPI specification.",
"author": "Ferdi Koomen",
"homepage": "https://github.com/CanoaPBC/openapi-typescript-codegen",
Expand Down Expand Up @@ -90,8 +90,8 @@
"@types/express": "4.17.21",
"@types/fs-extra": "^11.0.4",
"@types/glob": "8.1.0",
"@types/jest": "29.5.11",
"@types/node": "20.11.14",
"@types/jest": "29.5.12",
"@types/node": "20.11.16",
"@types/node-fetch": "2.6.10",
"@types/qs": "6.9.11",
"@typescript-eslint/eslint-plugin": "6.20.0",
Expand All @@ -111,7 +111,7 @@
"jest-cli": "29.7.0",
"node-fetch": "2.7.0",
"prettier": "3.2.4",
"puppeteer": "21.10.0",
"puppeteer": "21.11.0",
"qs": "6.11.2",
"rimraf": "5.0.5",
"rollup": "4.7.0",
Expand Down
3 changes: 3 additions & 0 deletions src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ export type Options = {
clientName?: string;
useOptions?: boolean;
useUnionTypes?: boolean;
autoformat?: boolean;
exportCore?: boolean;
exportServices?: boolean | string;
exportModels?: boolean | string;
Expand Down Expand Up @@ -57,6 +58,7 @@ export const generate = async ({
clientName,
useOptions = false,
useUnionTypes = false,
autoformat = false,
exportCore = true,
exportServices = true,
exportModels = true,
Expand Down Expand Up @@ -100,6 +102,7 @@ export const generate = async ({
httpClient,
useOptions,
useUnionTypes,
autoformat,
exportCore,
exportServices,
exportModels,
Expand Down
1 change: 1 addition & 0 deletions src/utils/writeClient.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ describe('writeClient', () => {
HttpClient.FETCH,
false,
false,
false,
true,
true,
true,
Expand Down
13 changes: 13 additions & 0 deletions src/utils/writeClient.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
import { spawnSync } from 'child_process';
import { createRequire } from 'module';
import { resolve } from 'path';

import type { Client } from '../client/interfaces/Client';
Expand Down Expand Up @@ -40,6 +42,7 @@ export const writeClient = async (
httpClient: HttpClient,
useOptions: boolean,
useUnionTypes: boolean,
autoformat: boolean,
exportCore: boolean,
exportServices: boolean | string,
exportModels: boolean | string,
Expand Down Expand Up @@ -125,4 +128,14 @@ export const writeClient = async (
clientName
);
}

if (autoformat) {
const pathPackageJson = resolve(process.cwd(), 'package.json');
const require = createRequire('/');
const json = require(pathPackageJson);
const usesPrettier = [json.dependencies, json.devDependencies].some(deps => Boolean(deps.prettier));
if (usesPrettier) {
spawnSync('prettier', ['--ignore-unknown', '--write', output]);
}
}
};
1 change: 1 addition & 0 deletions test/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ const generate = async (input, output) => {
httpClient: OpenAPI.HttpClient.FETCH,
useOptions: true,
useUnionTypes: false,
autoformat: false,
exportCore: true,
exportSchemas: true,
exportModels: true,
Expand Down
2 changes: 2 additions & 0 deletions test/index.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ describe('v2', () => {
httpClient: HttpClient.FETCH,
useOptions: false,
useUnionTypes: false,
autoformat: false,
exportCore: true,
exportSchemas: true,
exportModels: true,
Expand All @@ -32,6 +33,7 @@ describe('v3', () => {
httpClient: HttpClient.FETCH,
useOptions: false,
useUnionTypes: false,
autoformat: false,
exportCore: true,
exportSchemas: true,
exportModels: true,
Expand Down
1 change: 1 addition & 0 deletions types/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ export type Options = {
clientName?: string;
useOptions?: boolean;
useUnionTypes?: boolean;
autoformat?: boolean;
exportCore?: boolean;
exportServices?: boolean | string;
exportModels?: boolean | string;
Expand Down

0 comments on commit 7a3c689

Please sign in to comment.