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

refactor(build): Pre-compile files imported from data folder #7896

Merged
merged 13 commits into from
Dec 8, 2020
7 changes: 3 additions & 4 deletions lib/manager/pip_setup/util.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { resolveFile } from '../../util';
import { readFile, readLocalFile, writeLocalFile } from '../../util/fs';
import dataFiles from '../../data-files.generated';
import { readLocalFile, writeLocalFile } from '../../util/fs';

// need to match filename in `data/extract.py`
const REPORT = 'renovate-pip_setup-report.json';
Expand All @@ -9,8 +9,7 @@ let extractPy: string | undefined;

export async function copyExtractFile(): Promise<string> {
if (extractPy === undefined) {
const file = await resolveFile('data/extract.py');
extractPy = await readFile(file, 'utf8');
extractPy = dataFiles.get('extract.py');
}

await writeLocalFile(EXTRACT, extractPy);
Expand Down
15 changes: 8 additions & 7 deletions lib/manager/travis/package.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import is from '@sindresorhus/is';
import equal from 'fast-deep-equal';
import dataFiles from '../../data-files.generated';
import { getPkgReleases } from '../../datasource';
import * as datasourceGithubTags from '../../datasource/github-tags';
import { logger } from '../../logger';
import { resolveFile } from '../../util';
import { isVersion, maxSatisfyingVersion } from '../../versioning/semver';
import { LookupUpdate, PackageUpdateConfig } from '../common';

Expand All @@ -26,9 +26,10 @@ type NodeJsData = Record<string, NodeJsSchedule>;
let policies: NodeJsPolicies;
let refreshDate: Date;

async function generatePolicies(): Promise<NodeJsData> {
const file = await resolveFile('data/node-js-schedule.json');
const nodeJsSchedule = (await import(file)) as NodeJsData;
function generatePolicies(): NodeJsData {
const nodeJsSchedule = JSON.parse(
dataFiles.get('node-js-schedule.json')
) as NodeJsData;
policies = {
all: [],
lts: [],
Expand Down Expand Up @@ -65,11 +66,11 @@ async function generatePolicies(): Promise<NodeJsData> {
return nodeJsSchedule;
}

async function checkPolicies(): Promise<void> {
function checkPolicies(): void {
if (policies && refreshDate > new Date()) {
return;
}
const nodeJsSchedule = await generatePolicies();
const nodeJsSchedule = generatePolicies();
refreshDate = new Date('3000-01-01'); // y3k
const now = new Date();
for (const data of Object.values(nodeJsSchedule)) {
Expand All @@ -92,7 +93,7 @@ export async function getPackageUpdates(
if (!supportPolicy?.length) {
return [];
}
await checkPolicies();
checkPolicies();
for (const policy of supportPolicy) {
if (!Object.keys(policies).includes(policy)) {
logger.warn({ policy }, `Unknown supportPolicy`);
Expand Down
43 changes: 42 additions & 1 deletion tools/generate-imports.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,11 @@ if (!fs.existsSync('lib')) {
shell.exit(0);
}

if (!fs.existsSync('data')) {
shell.echo('> missing data folder');
shell.exit(0);
}

function findModules(dirname: string): string[] {
return fs
.readdirSync(dirname, { withFileTypes: true })
Expand All @@ -17,6 +22,7 @@ function findModules(dirname: string): string[] {
.filter((name) => !name.startsWith('__'))
.sort();
}

async function updateFile(file: string, code: string): Promise<void> {
const oldCode = fs.existsSync(file) ? await fs.readFile(file, 'utf8') : null;
if (code !== oldCode) {
Expand Down Expand Up @@ -44,7 +50,7 @@ async function generate({
map?: string;
excludes?: string[];
}): Promise<void> {
shell.echo(`> ${path}`);
shell.echo(`> lib/${path}/`);
let imports = '';
let maps = '';
for (const ds of findModules(`lib/${path}`).filter(
Expand All @@ -64,9 +70,44 @@ async function generate({
await updateFile(`lib/${path}/api.generated.ts`, code.replace(/^\s+/gm, ''));
}

async function generateData(): Promise<void> {
const files = fs
.readdirSync('data', { withFileTypes: true })
.filter((dirent) => dirent.isFile())
.map((dirent) => dirent.name)
.sort();

const importDataFileType = files.map((x) => ` | '${x}'`).join('\n');

const contentMapDecl = 'const data = new Map<DataFile, string>();';

const contentMapAssignments = [];
zharinov marked this conversation as resolved.
Show resolved Hide resolved
for (const file of files) {
shell.echo(`> data/${file}`);
const rawFileContent = await fs.readFile(`data/${file}`, 'utf8');
const prettyFileContent = `\n${rawFileContent.replace(/`/g, '\\`')}\n`;
zharinov marked this conversation as resolved.
Show resolved Hide resolved
contentMapAssignments.push(
`data.set('${file}', \`${prettyFileContent}\`.slice(1, -1));`
);
}

await updateFile(
`lib/data-files.generated.ts`,
[
`type DataFile =\n${importDataFileType};`,
contentMapDecl,
...contentMapAssignments,
`export default data;\n`,
].join('\n\n')
);
}

// eslint-disable-next-line @typescript-eslint/no-floating-promises
(async () => {
try {
// data-files
await generateData();

// datasources
await generate({ path: 'datasource', types: ['DatasourceApi'] });

Expand Down