本文整理匯總了TypeScript中@angular-devkit/architect/testing.TestLogger.pipe方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript TestLogger.pipe方法的具體用法?TypeScript TestLogger.pipe怎麽用?TypeScript TestLogger.pipe使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類@angular-devkit/architect/testing.TestLogger
的用法示例。
在下文中一共展示了TestLogger.pipe方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: it
it('file replacements work with forked type checker on watch mode', async () => {
host.writeMultipleFiles({
'src/file-replaced.ts': 'export var obj = { one: 1, two: 2 };',
'src/file.ts': `export var obj = { one: 1 };`,
'src/main.ts': `
import { obj } from './file';
console.log(obj.two);
`,
});
const overrides = {
fileReplacements: [{
replace: normalize('/src/file.ts'),
with: normalize('/src/file-replaced.ts'),
}],
watch: true,
};
const unexpectedError = `Property 'two' does not exist on type '{ one: number; }'`;
const expectedError = `Property 'prop' does not exist on type '{}'`;
const logger = new TestLogger('rebuild-type-errors');
// Race between a timeout and the expected log entry.
const stop$ = race<null | string>(
of(null).pipe(delay(45000 * 2 / 3)),
logger.pipe(
filter(entry => entry.message.includes(expectedError)),
map(entry => entry.message),
take(1),
),
);
let errorAdded = false;
const run = await architect.scheduleTarget(target, overrides, { logger });
run.output.pipe(
tap((buildEvent) => expect(buildEvent.success).toBe(true, 'build should succeed')),
tap(() => {
// Introduce a known type error to detect in the logger filter.
if (!errorAdded) {
host.appendToFile('src/main.ts', 'console.log({}.prop);');
errorAdded = true;
}
}),
takeUntil(stop$),
).subscribe();
const res = await stop$.toPromise();
expect(res).not.toBe(null, 'Test timed out.');
expect(res).not.toContain(unexpectedError);
await run.stop();
});