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(plugin-jsdocs): add plugin-jsdocs to analyze documentation in ts/js projects #896

Open
wants to merge 62 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
62 commits
Select commit Hold shift + click to select a range
bf1775d
feat(plugin-doc-coverage): add mvp version of a plugin doc coverage b…
aramirezj Dec 17, 2024
b07eb8a
feat: change from compodoc to typedoc
aramirezj Dec 17, 2024
0de6d3f
feat(plugin-doc-coverage): change to use ts-morph instead of typedoc.…
aramirezj Dec 18, 2024
164a86a
feat: doc-processer give coverage by type of property. Some tests enh…
aramirezj Dec 18, 2024
3fe6e3b
feat(plugin-doc-coverage): improve code fragmentation, tests and mode…
aramirezj Dec 20, 2024
40c8daa
test(plugin-doc-coverage): finish remaining tests, add format to cove…
aramirezj Dec 20, 2024
47486c8
feat(plugin-doc-coverage): add skipAudits options to the plugin, crea…
aramirezj Dec 20, 2024
f21fbe2
chore(plugin-doc-coverage): fix linter problems
aramirezj Dec 20, 2024
4fb478e
fix: return code-pushup config to original state
aramirezj Dec 20, 2024
feefa0a
feat(plugin-doc-coverage): add support for variable statement to be d…
aramirezj Dec 21, 2024
1a5a614
chore(plugin-doc-coverage): remove unused file and update readme file
aramirezj Dec 21, 2024
8909855
Update packages/plugin-doc-coverage/src/lib/constants.ts
aramirezj Dec 22, 2024
b8cdf77
Update packages/plugin-doc-coverage/package.json
aramirezj Dec 22, 2024
24ab2e0
chore(plugin-doc-coverage): from Michael comments, remakes some tests…
aramirezj Dec 22, 2024
6c83208
chore(plugin-doc-coverage): remove extra line
aramirezj Dec 22, 2024
8c2d274
chore: put back plugin config
aramirezj Dec 22, 2024
a70c03b
chore: fix plugin config, remove unused snapshot
aramirezj Dec 22, 2024
6be3803
chore(plugin-doc-coverage): stuff of the pr and rename file
aramirezj Dec 22, 2024
2f29728
Update code-pushup.config.ts
aramirezj Dec 23, 2024
adec386
Update packages/plugin-doc-coverage/src/lib/doc-coverage-plugin.unit.…
aramirezj Dec 23, 2024
47cff4b
Update packages/plugin-doc-coverage/src/lib/runner/doc-processer.inte…
aramirezj Dec 23, 2024
c644029
Update packages/plugin-doc-coverage/src/lib/constants.ts
aramirezj Dec 23, 2024
09d9eb0
Update packages/plugin-doc-coverage/src/lib/constants.ts
aramirezj Dec 23, 2024
3901955
Update packages/plugin-doc-coverage/src/lib/constants.ts
aramirezj Dec 23, 2024
11ad4bb
Update packages/plugin-doc-coverage/src/lib/constants.ts
aramirezj Dec 23, 2024
19d43a5
Update packages/plugin-doc-coverage/src/lib/constants.ts
aramirezj Dec 23, 2024
49e5b56
Update packages/plugin-doc-coverage/README.md
aramirezj Dec 23, 2024
54d1621
Update packages/plugin-doc-coverage/README.md
aramirezj Dec 23, 2024
b3105ae
Update packages/plugin-doc-coverage/src/lib/constants.ts
aramirezj Dec 23, 2024
89893a0
Update packages/plugin-doc-coverage/src/lib/constants.ts
aramirezj Dec 23, 2024
97d32bf
Update packages/plugin-doc-coverage/src/lib/config.unit.test.ts
aramirezj Dec 23, 2024
79b6a02
Update packages/plugin-doc-coverage/src/lib/config.unit.test.ts
aramirezj Dec 23, 2024
fd3bd5e
chore(plugin-doc-coverage): add js files for integration test, remove…
aramirezj Dec 23, 2024
0ecc193
chore: run nx format
aramirezj Dec 23, 2024
7e0acbd
chore(plugin-doc-coverage): improve readme and audits
aramirezj Dec 23, 2024
24468cc
chore(plugin-doc-coverage): remove unused async
aramirezj Dec 23, 2024
ef77df0
chore(plugin-doc-coverage): fix tests, fully remove unnecessary await
aramirezj Dec 23, 2024
b09aa57
chore: fix scope of sourceGlob
aramirezj Dec 23, 2024
b9f5333
fix: mock word
aramirezj Dec 23, 2024
6f0f19c
chore: wips
aramirezj Jan 2, 2025
6634f3c
fix e2e
BioPhoton Jan 2, 2025
5fc371c
chore: nx format
aramirezj Jan 2, 2025
b609608
test(plugin-doc-coverage): create better test of integration
aramirezj Jan 3, 2025
2dbdb7d
chore(plugin-doc-coverage): fix lint
aramirezj Jan 3, 2025
da133e9
chore(plugin-doc-coverage): fix linter e2e
aramirezj Jan 3, 2025
7a80f85
polish integration tests
BioPhoton Jan 3, 2025
12e3f4e
wip
BioPhoton Jan 3, 2025
c9443a0
chore(plugin-doc-coverage): change string detection
aramirezj Jan 3, 2025
ac83605
chore: format
aramirezj Jan 3, 2025
1107ae4
chore: import
aramirezj Jan 3, 2025
7fc7c2e
Merge remote-tracking branch 'origin/main' into feat--plugin-doc-cove…
aramirezj Jan 9, 2025
b7a42c7
chore(plugin-doc-coverage): use new path matching helpers
aramirezj Jan 9, 2025
206340e
chore(plugin-doc-coverage): add setupFile for path matcher
aramirezj Jan 9, 2025
dec6fbd
Update code-pushup.preset.ts
aramirezj Jan 11, 2025
baac33c
Update packages/plugin-doc-coverage/README.md
aramirezj Jan 11, 2025
ac72432
Update code-pushup.preset.ts
aramirezj Jan 11, 2025
177a186
Update packages/plugin-doc-coverage/src/lib/runner/runner.unit.test.ts
aramirezj Jan 11, 2025
4531347
Update packages/plugin-doc-coverage/src/lib/doc-coverage-plugin.ts
aramirezj Jan 11, 2025
4700bea
Update packages/plugin-doc-coverage/src/lib/runner/doc-processer.ts
aramirezj Jan 11, 2025
c386373
chore(plugin-doc-coverage): wip request in pr
aramirezj Jan 11, 2025
4a75b86
chore(plugin-doc-coverage): rename processer to processor
aramirezj Jan 11, 2025
0089b1f
chore(plugin-jsdocs): rename plugin
aramirezj Jan 11, 2025
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
9 changes: 9 additions & 0 deletions code-pushup.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import { z } from 'zod';
import {
coverageCoreConfigNx,
eslintCoreConfigNx,
jsDocsCoreConfig,
jsPackagesCoreConfig,
lighthouseCoreConfig,
} from './code-pushup.preset.js';
Expand Down Expand Up @@ -39,4 +40,12 @@ export default mergeConfigs(
'https://github.com/code-pushup/cli?tab=readme-ov-file#code-pushup-cli/',
),
await eslintCoreConfigNx(),
jsDocsCoreConfig([
'packages/**/src/**/*.ts',
'!packages/**/node_modules',
'!packages/**/{mocks,mock}',
'!**/*.{spec,test}.ts',
'!**/implementation/**',
'!**/internal/**',
]),
);
39 changes: 39 additions & 0 deletions code-pushup.preset.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,14 @@ import eslintPlugin, {
eslintConfigFromNxProject,
} from './packages/plugin-eslint/src/index.js';
import jsPackagesPlugin from './packages/plugin-js-packages/src/index.js';
import jsDocsPlugin, {
JsDocsPluginConfig,
} from './packages/plugin-jsdocs/src/index.js';
import {
PLUGIN_SLUG,
groups,
} from './packages/plugin-jsdocs/src/lib/constants.js';
import { filterGroupsByOnlyAudits } from './packages/plugin-jsdocs/src/lib/utils.js';
import lighthousePlugin, {
lighthouseGroupRef,
} from './packages/plugin-lighthouse/src/index.js';
Expand Down Expand Up @@ -82,6 +90,24 @@ export const eslintCategories: CategoryConfig[] = [
},
];

export function getJsDocsCategories(
config: JsDocsPluginConfig,
): CategoryConfig[] {
return [
{
slug: 'docs',
title: 'Documentation',
description: 'Measures how much of your code is **documented**.',
refs: filterGroupsByOnlyAudits(groups, config).map(group => ({
weight: 1,
type: 'group',
plugin: PLUGIN_SLUG,
slug: group.slug,
})),
},
];
}

export const coverageCategories: CategoryConfig[] = [
{
slug: 'code-coverage',
Expand Down Expand Up @@ -114,6 +140,19 @@ export const lighthouseCoreConfig = async (
};
};

export const jsDocsCoreConfig = (
config: JsDocsPluginConfig | string[],
): CoreConfig => {
return {
plugins: [
jsDocsPlugin(Array.isArray(config) ? { patterns: config } : config),
],
categories: getJsDocsCategories(
Array.isArray(config) ? { patterns: config } : config,
),
};
};

export const eslintCoreConfigNx = async (
projectName?: string,
): Promise<CoreConfig> => {
Expand Down
12 changes: 12 additions & 0 deletions e2e/plugin-doc-coverage-e2e/eslint.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import tseslint from 'typescript-eslint';
import baseConfig from '../../eslint.config.js';

export default tseslint.config(...baseConfig, {
files: ['**/*.ts'],
languageOptions: {
parserOptions: {
projectService: true,
tsconfigRootDir: import.meta.dirname,
},
},
});
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import docCoveragePlugin from '@code-pushup/doc-coverage-plugin';

export default {
plugins: [await docCoveragePlugin({ sourceGlob: ['**/*.ts'] })],
};
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
h1 {
color: #336699;
text-align: center;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
<h1>{{ title }}</h1>
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
function notRealisticFunction() {
return 'notRealisticFunction';
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
/**
* Basic Angular component that displays a welcome message
*/
export class AppComponent {
protected readonly title = 'My Angular App';

/**
* Dummy method that returns a welcome message
* @returns {string} - The welcome message
*/
getWelcomeMessage() {
return 'Welcome to My Angular App!';
}

sendEvent() {
return 'Event sent';
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
export const someVariable = 'Hello World 1';

export function mapEventToCustomEvent(event: string) {
return event;
}

/** Commented */
export function mapCustomEventToEvent(event: string) {
return event;
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import docCoveragePlugin from '@code-pushup/doc-coverage-plugin';

export default {
plugins: [await docCoveragePlugin({ sourceGlob: ['**/*.ts'] })],
};
10 changes: 10 additions & 0 deletions e2e/plugin-doc-coverage-e2e/mocks/fixtures/react/component.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
function MyComponent() {
return (
<div>
<h1>Hello World</h1>
<p>This is a basic React component</p>
</div>
);
}

export default MyComponent;
23 changes: 23 additions & 0 deletions e2e/plugin-doc-coverage-e2e/project.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
{
"name": "plugin-doc-coverage-e2e",
"$schema": "../../node_modules/nx/schemas/project-schema.json",
"sourceRoot": "e2e/plugin-doc-coverage-e2e/src",
Copy link
Collaborator

Choose a reason for hiding this comment

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

Could you also rename the E2E project to plugin-jsdocs-e2e, so it matches the new name? 🙏

"projectType": "application",
"tags": ["scope:plugin", "type:e2e"],
"implicitDependencies": ["cli", "plugin-jsdocs"],
"targets": {
"lint": {
"executor": "@nx/linter:eslint",
"outputs": ["{options.outputFile}"],
"options": {
"lintFilePatterns": ["e2e/plugin-doc-coverage-e2e/**/*.ts"]
}
},
"e2e": {
"executor": "@nx/vite:test",
"options": {
"configFile": "e2e/plugin-doc-coverage-e2e/vite.config.e2e.ts"
}
}
}
}
72 changes: 72 additions & 0 deletions e2e/plugin-doc-coverage-e2e/tests/collect.e2e.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,72 @@
import { cp } from 'node:fs/promises';
import path from 'node:path';
import { afterAll, afterEach, beforeAll, describe, expect, it } from 'vitest';
import { type Report, reportSchema } from '@code-pushup/models';
import { nxTargetProject } from '@code-pushup/test-nx-utils';
import { teardownTestFolder } from '@code-pushup/test-setup';
import {
E2E_ENVIRONMENTS_DIR,
TEST_OUTPUT_DIR,
omitVariableReportData,
removeColorCodes,
} from '@code-pushup/test-utils';
import { executeProcess, readJsonFile } from '@code-pushup/utils';

describe('PLUGIN collect report with doc-coverage-plugin NPM package', () => {
const fixturesDir = path.join(
'e2e',
'plugin-doc-coverage-e2e',
'mocks',
'fixtures',
);
const fixturesAngularDir = path.join(fixturesDir, 'angular');
const fixturesReactDir = path.join(fixturesDir, 'react');

const envRoot = path.join(
E2E_ENVIRONMENTS_DIR,
nxTargetProject(),
TEST_OUTPUT_DIR,
);
const angularDir = path.join(envRoot, 'angular');
const reactDir = path.join(envRoot, 'react');
const angularOutputDir = path.join(angularDir, '.code-pushup');
const reactOutputDir = path.join(reactDir, '.code-pushup');

beforeAll(async () => {
await cp(fixturesAngularDir, angularDir, { recursive: true });
await cp(fixturesReactDir, reactDir, { recursive: true });
});

afterAll(async () => {
await teardownTestFolder(angularDir);
await teardownTestFolder(reactDir);
});

afterEach(async () => {
await teardownTestFolder(angularOutputDir);
await teardownTestFolder(reactOutputDir);
});

it('should run Doc Coverage plugin for Angular example dir and create report.json', async () => {
const { code, stdout } = await executeProcess({
command: 'npx',
args: ['@code-pushup/cli', 'collect', '--no-progress'],
cwd: angularDir,
});

expect(code).toBe(0);

expect(removeColorCodes(stdout)).toMatchFileSnapshot(
'__snapshots__/report.txt',
);

const report = await readJsonFile(
path.join(angularOutputDir, 'report.json'),
);

expect(() => reportSchema.parse(report)).not.toThrow();
expect(
JSON.stringify(omitVariableReportData(report as Report), null, 2),
).toMatchFileSnapshot('__snapshots__/report.json');
});
});
20 changes: 20 additions & 0 deletions e2e/plugin-doc-coverage-e2e/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
{
"extends": "../../tsconfig.base.json",
"compilerOptions": {
"module": "ESNext",
"forceConsistentCasingInFileNames": true,
"strict": true,
"noImplicitOverride": true,
"noPropertyAccessFromIndexSignature": true,
"noImplicitReturns": true,
"noFallthroughCasesInSwitch": true,
"types": ["vitest"]
},
"files": [],
"include": [],
"references": [
{
"path": "./tsconfig.test.json"
}
]
}
15 changes: 15 additions & 0 deletions e2e/plugin-doc-coverage-e2e/tsconfig.test.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
{
"extends": "./tsconfig.json",
"compilerOptions": {
"outDir": "../../dist/out-tsc",
"types": ["vitest/globals", "vitest/importMeta", "vite/client", "node"],
"target": "ES2020"
},
"exclude": ["__test-env__/**"],
"include": [
"vite.config.e2e.ts",
"tests/**/*.e2e.test.ts",
"tests/**/*.d.ts",
"mocks/**/*.ts"
]
}
21 changes: 21 additions & 0 deletions e2e/plugin-doc-coverage-e2e/vite.config.e2e.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
/// <reference types="vitest" />
import { defineConfig } from 'vite';
import { tsconfigPathAliases } from '../../tools/vitest-tsconfig-path-aliases.js';

export default defineConfig({
cacheDir: '../../node_modules/.vite/plugin-doc-coverage-e2e',
test: {
reporters: ['basic'],
testTimeout: 120_000,
globals: true,
alias: tsconfigPathAliases(),
pool: 'threads',
poolOptions: { threads: { singleThread: true } },
cache: {
dir: '../../node_modules/.vitest',
},
environment: 'node',
include: ['tests/**/*.e2e.test.{js,mjs,cjs,ts,mts,cts,jsx,tsx}'],
setupFiles: ['../../testing/test-setup/src/lib/reset.mocks.ts'],
},
});
Loading
Loading