remove the last src/run.ts

Signed-off-by: Fredrik Adelöw <freben@gmail.com>
This commit is contained in:
Fredrik Adelöw
2024-11-19 13:32:34 +01:00
parent 22c4ecc6c7
commit cbfc69e4d4
14 changed files with 106 additions and 257 deletions
+5
View File
@@ -0,0 +1,5 @@
---
'@backstage/cli-node': patch
---
Internal refactor
+6
View File
@@ -0,0 +1,6 @@
---
'@backstage/plugin-catalog-backend-module-incremental-ingestion': patch
'@backstage/plugin-kubernetes-backend': patch
---
Create a `dev/index.ts` entrypoint for `yarn start`
+1 -2
View File
@@ -15,8 +15,7 @@
*/
import { assertError, ForwardedError } from '@backstage/errors';
import { paths } from '../paths';
import { execFile } from '../run';
import { execFile, paths } from '../util';
/**
* Run a git command, trimming the output splitting it into lines.
@@ -23,7 +23,7 @@ import { GitUtils } from '../git';
const mockListChangedFiles = jest.spyOn(GitUtils, 'listChangedFiles');
const mockReadFileAtRef = jest.spyOn(GitUtils, 'readFileAtRef');
jest.mock('../paths', () => ({
jest.mock('../util', () => ({
paths: {
targetRoot: '/',
resolveTargetRoot: (...paths: string[]) => resolvePath('/', ...paths),
@@ -16,7 +16,7 @@
import path from 'path';
import { getPackages, Package } from '@manypkg/get-packages';
import { paths } from '../paths';
import { paths } from '../util';
import { PackageRole } from '../roles';
import { GitUtils } from '../git';
import { Lockfile } from './Lockfile';
+1 -1
View File
@@ -14,7 +14,7 @@
* limitations under the License.
*/
import { paths } from '../paths';
import { paths } from '../util';
import fs from 'fs-extra';
/**
@@ -19,7 +19,7 @@ import { createMockDirectory } from '@backstage/backend-test-utils';
const mockDir = createMockDirectory();
jest.mock('../paths', () => ({
jest.mock('../util', () => ({
paths: { resolveTargetRoot: (...args: string[]) => mockDir.resolve(...args) },
}));
@@ -14,7 +14,11 @@
* limitations under the License.
*/
import { execFile as execFileCb } from 'child_process';
import { promisify } from 'util';
import { findPaths } from '@backstage/cli-common';
export const execFile = promisify(execFileCb);
/* eslint-disable-next-line no-restricted-syntax */
export const paths = findPaths(__dirname);
@@ -0,0 +1,81 @@
/*
* Copyright 2024 The Backstage Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { createBackend } from '@backstage/backend-defaults';
import {
coreServices,
createBackendModule,
} from '@backstage/backend-plugin-api';
import { mockServices } from '@backstage/backend-test-utils';
import {
IncrementalEntityProvider,
incrementalIngestionProvidersExtensionPoint,
} from '../src';
const dummyProvider = createBackendModule({
pluginId: 'catalog',
moduleId: 'incremental-test-provider',
register(reg) {
reg.registerInit({
deps: {
logger: coreServices.logger,
providers: incrementalIngestionProvidersExtensionPoint,
},
async init({ logger, providers }) {
const provider: IncrementalEntityProvider<number, {}> = {
getProviderName: () => 'test-provider',
around: burst => burst(0),
next: async (_context, cursor) => {
await new Promise(resolve => setTimeout(resolve, 500));
if (cursor === undefined || cursor < 3) {
logger.info(`### Returning batch #${cursor}`);
return { done: false, entities: [], cursor: (cursor ?? 0) + 1 };
}
logger.info('### Last batch reached, stopping');
return { done: true };
},
};
providers.addProvider({
provider: provider,
options: {
burstInterval: { seconds: 1 },
burstLength: { seconds: 10 },
restLength: { seconds: 10 },
},
});
},
});
},
});
const backend = createBackend();
backend.add(
mockServices.rootConfig.factory({
data: {
backend: {
baseUrl: 'http://localhost:7007',
listen: ':7007',
database: { client: 'better-sqlite3', connection: ':memory:' },
},
},
}),
);
backend.add(import('@backstage/plugin-catalog-backend'));
backend.add(import('../src'));
backend.add(dummyProvider);
backend.start();
@@ -1,96 +0,0 @@
/*
* Copyright 2022 The Backstage Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
// Think this file will probably go away once we move to backend system
// And restructure into the /dev folder
// eslint-disable-next-line @backstage/no-undeclared-imports
import { createBackend } from '@backstage/backend-defaults';
import {
coreServices,
createBackendModule,
createServiceFactory,
} from '@backstage/backend-plugin-api';
import { ConfigReader } from '@backstage/config';
import {
IncrementalEntityProvider,
incrementalIngestionProvidersExtensionPoint,
} from '.';
import catalogModuleIncrementalIngestionEntityProvider from './alpha';
const provider: IncrementalEntityProvider<number, {}> = {
getProviderName: () => 'test-provider',
around: burst => burst(0),
next: async (_context, cursor) => {
await new Promise(resolve => setTimeout(resolve, 500));
if (cursor === undefined || cursor < 3) {
console.log(`### Returning batch #${cursor}`);
return { done: false, entities: [], cursor: (cursor ?? 0) + 1 };
}
console.log('### Last batch reached, stopping');
return { done: true };
},
};
async function main() {
const config = {
backend: {
baseUrl: 'http://localhost:7007',
listen: ':7007',
database: { client: 'better-sqlite3', connection: ':memory:' },
},
};
const backend = createBackend();
backend.add(
createServiceFactory({
service: coreServices.rootConfig,
deps: {},
factory: () => new ConfigReader(config),
}),
);
backend.add(import('@backstage/plugin-catalog-backend/alpha'));
backend.add(catalogModuleIncrementalIngestionEntityProvider);
backend.add(
createBackendModule({
pluginId: 'catalog',
moduleId: 'incremental-test-provider',
register(reg) {
reg.registerInit({
deps: { extension: incrementalIngestionProvidersExtensionPoint },
async init({ extension }) {
extension.addProvider({
provider: provider,
options: {
burstInterval: { seconds: 1 },
burstLength: { seconds: 10 },
restLength: { seconds: 10 },
},
});
},
});
},
}),
);
await backend.start();
}
main().catch(error => {
console.error(error.stack);
process.exit(1);
});
@@ -1,5 +1,5 @@
/*
* Copyright 2020 The Backstage Authors
* Copyright 2024 The Backstage Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@@ -14,7 +14,8 @@
* limitations under the License.
*/
import { execFile as execFileCb } from 'child_process';
import { promisify } from 'util';
import { createBackend } from '@backstage/backend-defaults';
export const execFile = promisify(execFileCb);
const backend = createBackend();
backend.add(import('../src'));
backend.start();
-33
View File
@@ -1,33 +0,0 @@
/*
* Copyright 2020 The Backstage Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import yn from 'yn';
import { getRootLogger } from '@backstage/backend-common';
import { startStandaloneServer } from './service/standaloneServer';
const port = process.env.PLUGIN_PORT ? Number(process.env.PLUGIN_PORT) : 3004;
const enableCors = yn(process.env.PLUGIN_CORS, { default: false });
const logger = getRootLogger();
startStandaloneServer({ port, enableCors, logger }).catch(err => {
logger.error(err);
process.exit(1);
});
process.on('SIGINT', () => {
logger.info('CTRL+C pressed; exiting.');
process.exit(0);
});
@@ -1,68 +0,0 @@
/*
* Copyright 2020 The Backstage Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import {
errorHandler,
notFoundHandler,
requestLoggingHandler,
HostDiscovery,
} from '@backstage/backend-common';
import compression from 'compression';
import cors from 'cors';
import express from 'express';
import helmet from 'helmet';
import { Logger } from 'winston';
import { createRouter } from './router';
import { ConfigReader } from '@backstage/config';
import { CatalogClient } from '@backstage/catalog-client';
import { PermissionEvaluator } from '@backstage/plugin-permission-common';
export interface ApplicationOptions {
enableCors: boolean;
logger: Logger;
}
export async function createStandaloneApplication(
options: ApplicationOptions,
): Promise<express.Application> {
const { enableCors, logger } = options;
const config = new ConfigReader({});
const discovery = HostDiscovery.fromConfig(config);
const app = express();
const catalogApi = new CatalogClient({
discoveryApi: HostDiscovery.fromConfig(config),
});
const permissions = {} as PermissionEvaluator;
app.use(helmet());
if (enableCors) {
app.use(cors());
}
app.use(compression());
app.use(express.json());
app.use(requestLoggingHandler());
app.use(
'/',
await createRouter({ logger, config, discovery, catalogApi, permissions }),
);
app.use(notFoundHandler());
app.use(errorHandler());
return app;
}
@@ -1,50 +0,0 @@
/*
* Copyright 2020 The Backstage Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { Server } from 'http';
import { Logger } from 'winston';
import { createStandaloneApplication } from './standaloneApplication';
export interface ServerOptions {
port: number;
enableCors: boolean;
logger: Logger;
}
export async function startStandaloneServer(
options: ServerOptions,
): Promise<Server> {
const logger = options.logger.child({ service: 'kubernetes-backend' });
logger.debug('Creating application...');
const app = await createStandaloneApplication({
enableCors: options.enableCors,
logger,
});
logger.debug('Starting application server...');
return await new Promise((resolve, reject) => {
const server = app.listen(options.port, (err?: Error) => {
if (err) {
reject(err);
return;
}
logger.info(`Listening on port ${options.port}`);
resolve(server);
});
});
}