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

Open
wants to merge 53 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 43 commits
Commits
Show all changes
53 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
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
11 changes: 11 additions & 0 deletions code-pushup.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import 'dotenv/config';
import { z } from 'zod';
import {
coverageCoreConfigNx,
docCoverageCoreConfig,
eslintCoreConfigNx,
jsPackagesCoreConfig,
lighthouseCoreConfig,
Expand Down Expand Up @@ -39,4 +40,14 @@ export default mergeConfigs(
'https://github.com/code-pushup/cli?tab=readme-ov-file#code-pushup-cli/',
),
await eslintCoreConfigNx(),
await docCoverageCoreConfig({
sourceGlob: [
'packages/**/src/**/*.ts',
'!packages/**/node_modules',
'!packages/**/{mocks,mock}',
'!**/*.{spec,test}.ts',
'!**/implementation/**',
'!**/internal/**',
],
}),
Comment on lines +43 to +52
Copy link
Collaborator

Choose a reason for hiding this comment

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

The ESLint plugin has a similar parameter called patterns, would be nice to have consistent naming.

Suggested change
await docCoverageCoreConfig({
sourceGlob: [
'packages/**/src/**/*.ts',
'!packages/**/node_modules',
'!packages/**/{mocks,mock}',
'!**/*.{spec,test}.ts',
'!**/implementation/**',
'!**/internal/**',
],
}),
await docCoverageCoreConfig({
patterns: [
'packages/**/src/**/*.ts',
'!packages/**/node_modules',
'!packages/**/{mocks,mock}',
'!**/*.{spec,test}.ts',
'!**/implementation/**',
'!**/internal/**',
],
}),

Since I'm guessing only these globs are needed for most usages, the plugin parameter could also enable a shorthand (again, similar to ESLint plugin):

Suggested change
await docCoverageCoreConfig({
sourceGlob: [
'packages/**/src/**/*.ts',
'!packages/**/node_modules',
'!packages/**/{mocks,mock}',
'!**/*.{spec,test}.ts',
'!**/implementation/**',
'!**/internal/**',
],
}),
await docCoverageCoreConfig([
'packages/**/src/**/*.ts',
'!packages/**/node_modules',
'!packages/**/{mocks,mock}',
'!**/*.{spec,test}.ts',
'!**/implementation/**',
'!**/internal/**',
),

);
35 changes: 35 additions & 0 deletions code-pushup.preset.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,14 @@ import type {
import coveragePlugin, {
getNxCoveragePaths,
} from './packages/plugin-coverage/src/index.js';
import docCoveragePlugin, {
DocCoveragePluginConfig,
} from './packages/plugin-doc-coverage/src/index.js';
import {
PLUGIN_SLUG,
groups,
} from './packages/plugin-doc-coverage/src/lib/constants.js';
import { filterGroupsByOnlyAudits } from './packages/plugin-doc-coverage/src/lib/utils.js';
import eslintPlugin, {
eslintConfigFromAllNxProjects,
eslintConfigFromNxProject,
Expand Down Expand Up @@ -82,6 +90,24 @@ export const eslintCategories: CategoryConfig[] = [
},
];

export function getDocCoverageCategories(
config: DocCoveragePluginConfig,
): CategoryConfig[] {
return [
{
slug: 'doc-coverage-cat',
title: 'Documentation coverage',
Comment on lines +98 to +99
Copy link
Collaborator

Choose a reason for hiding this comment

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

We don't use a -cat suffix for any other category slugs, it's implicit from context.

Also, it's best for category names to be as short as possible, since they are very high-level. How about just Documentation/docs?

Suggested change
slug: 'doc-coverage-cat',
title: 'Documentation coverage',
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,15 @@ export const lighthouseCoreConfig = async (
};
};

export const docCoverageCoreConfig = async (
config: DocCoveragePluginConfig,
): Promise<CoreConfig> => {
return {
plugins: [docCoveragePlugin(config)],
categories: getDocCoverageCategories(config),
};
};
Comment on lines +143 to +150
Copy link
Collaborator

Choose a reason for hiding this comment

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

Doesn't need to be async:

Suggested change
export const docCoverageCoreConfig = async (
config: DocCoveragePluginConfig,
): Promise<CoreConfig> => {
return {
plugins: [docCoveragePlugin(config)],
categories: getDocCoverageCategories(config),
};
};
export const docCoverageCoreConfig = (
config: DocCoveragePluginConfig,
): CoreConfig => {
return {
plugins: [docCoveragePlugin(config)],
categories: getDocCoverageCategories(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",
"projectType": "application",
"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"
}
}
},
"implicitDependencies": ["cli", "plugin-doc-coverage"],
"tags": ["scope:plugin", "type:e2e"]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,201 @@
// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html

exports[`PLUGIN collect report with doc-coverage-plugin NPM package > should run Doc Coverage plugin for Angular example dir and create report.json 1`] = `
{
"packageName": "@code-pushup/core",
"plugins": [
{
"audits": [
{
"description": "Documentation coverage of enums",
"details": {
"issues": [],
},
"displayValue": "0 undocumented enums",
"score": 1,
"slug": "enums-coverage",
"title": "Enums coverage",
"value": 0,
},
{
"description": "Documentation coverage of interfaces",
"details": {
"issues": [],
},
"displayValue": "0 undocumented interfaces",
"score": 1,
"slug": "interfaces-coverage",
"title": "Interfaces coverage",
"value": 0,
},
{
"description": "Documentation coverage of types",
"details": {
"issues": [],
},
"displayValue": "0 undocumented types",
"score": 1,
"slug": "types-coverage",
"title": "Types coverage",
"value": 0,
},
{
"description": "Documentation coverage of functions",
"details": {
"issues": [
{
"message": "Missing documentation",
"severity": "warning",
"source": {
"file": "tmp/e2e/plugin-doc-coverage-e2e/__test__/angular/src/app.component.spec.ts",
"position": {
"startLine": 1,
},
},
},
{
"message": "Missing documentation",
"severity": "warning",
"source": {
"file": "tmp/e2e/plugin-doc-coverage-e2e/__test__/angular/src/map-event.function.ts",
"position": {
"startLine": 3,
},
},
},
],
},
"displayValue": "2 undocumented functions",
"score": 0.3333,
"slug": "functions-coverage",
"title": "Functions coverage",
"value": 2,
},
{
"description": "Documentation coverage of variables",
"details": {
"issues": [
{
"message": "Missing documentation",
"severity": "warning",
"source": {
"file": "tmp/e2e/plugin-doc-coverage-e2e/__test__/angular/src/map-event.function.ts",
"position": {
"startLine": 1,
},
},
},
],
},
"displayValue": "1 undocumented variables",
"score": 0,
"slug": "variables-coverage",
"title": "Variables coverage",
"value": 1,
},
{
"description": "Documentation coverage of classes",
"details": {
"issues": [],
},
"displayValue": "0 undocumented classes",
"score": 1,
"slug": "classes-coverage",
"title": "Classes coverage",
"value": 0,
},
{
"description": "Documentation coverage of methods",
"details": {
"issues": [
{
"message": "Missing documentation",
"severity": "warning",
"source": {
"file": "tmp/e2e/plugin-doc-coverage-e2e/__test__/angular/src/app.component.ts",
"position": {
"startLine": 15,
},
},
},
],
},
"displayValue": "1 undocumented methods",
"score": 0.5,
"slug": "methods-coverage",
"title": "Methods coverage",
"value": 1,
},
{
"description": "Documentation coverage of properties",
"details": {
"issues": [
{
"message": "Missing documentation",
"severity": "warning",
"source": {
"file": "tmp/e2e/plugin-doc-coverage-e2e/__test__/angular/src/app.component.ts",
"position": {
"startLine": 5,
},
},
},
],
},
"displayValue": "1 undocumented properties",
"score": 0,
"slug": "properties-coverage",
"title": "Properties coverage",
"value": 1,
},
],
"description": "Official Code PushUp documentation coverage plugin.",
"docsUrl": "https://www.npmjs.com/package/@code-pushup/doc-coverage-plugin/",
"groups": [
{
"description": "Documentation coverage",
"refs": [
{
"slug": "classes-coverage",
"weight": 2,
},
{
"slug": "methods-coverage",
"weight": 2,
},
{
"slug": "functions-coverage",
"weight": 2,
},
{
"slug": "interfaces-coverage",
"weight": 1,
},
{
"slug": "variables-coverage",
"weight": 1,
},
{
"slug": "properties-coverage",
"weight": 1,
},
{
"slug": "types-coverage",
"weight": 1,
},
{
"slug": "enums-coverage",
"weight": 1,
},
],
"slug": "documentation-coverage",
"title": "Documentation coverage",
},
],
"icon": "folder-src",
"slug": "doc-coverage",
"title": "Documentation coverage",
},
],
}
`;
Loading
Loading