Skip to content

Commit

Permalink
fix(material/core): test environment check not picking up jest (#23722)
Browse files Browse the repository at this point in the history
In #23636 the test environment check was changed so that it looks for the test objects either on `window` or `global`, however it looks like this isn't enough to pick up Jest which isn't published on either.

These changes simplify the setup by looking up the value globally and disabling the type checkng error with `@ts-ignore`. We can't use `declare const` for it, because it causes issues in g3.

I've also reverted some of the `any` types that had to be added in #23636.

Fixes #23365.

(cherry picked from commit ff7fd48)
  • Loading branch information
crisbeto authored and amysorto committed Nov 8, 2021
1 parent 985ffce commit 2fc63ef
Show file tree
Hide file tree
Showing 15 changed files with 29 additions and 45 deletions.
4 changes: 2 additions & 2 deletions src/cdk/a11y/focus-monitor/focus-monitor.ts
Original file line number Diff line number Diff line change
Expand Up @@ -95,10 +95,10 @@ export class FocusMonitor implements OnDestroy {
private _windowFocused = false;

/** The timeout id of the window focus timeout. */
private _windowFocusTimeoutId: any;
private _windowFocusTimeoutId: number;

/** The timeout id of the origin clearing timeout. */
private _originTimeoutId: any;
private _originTimeoutId: number;

/**
* Whether the origin was determined via a touch interaction. Necessary as properly attributing
Expand Down
2 changes: 1 addition & 1 deletion src/cdk/a11y/live-announcer/live-announcer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ import {
export class LiveAnnouncer implements OnDestroy {
private _liveElement: HTMLElement;
private _document: Document;
private _previousTimeout: any;
private _previousTimeout: number;

constructor(
@Optional() @Inject(LIVE_ANNOUNCER_ELEMENT_TOKEN) elementToken: any,
Expand Down
2 changes: 1 addition & 1 deletion src/cdk/overlay/overlay-ref.ts
Original file line number Diff line number Diff line change
Expand Up @@ -418,7 +418,7 @@ export class OverlayRef implements PortalOutlet, OverlayReference {
return;
}

let timeoutId: any;
let timeoutId: number;
const finishDetach = () => {
// It may not be attached to anything in certain cases (e.g. unit tests).
if (backdropToDetach) {
Expand Down
1 change: 0 additions & 1 deletion src/cdk/platform/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ ng_module(
deps = [
"@npm//@angular/common",
"@npm//@angular/core",
"@npm//@types/node",
],
)

Expand Down
39 changes: 12 additions & 27 deletions src/cdk/platform/features/test-environment.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,35 +6,20 @@
* found in the LICENSE file at https://angular.io/license
*/

// Avoid using `declare const` because it caused conflicts inside Google
// with the real typings for these symbols. We use `declare interface` instead
// of just `interface` for interop with Closure Compiler (prevents property renaming):
// https://github.com/angular/tsickle/blob/master/README.md#differences-from-typescript
declare interface TestGlobals {
jasmine: unknown;
__karma__: unknown;
jest: unknown;
Mocha: unknown;
}

let testGlobals: TestGlobals;

// We check the Node-specific `global` first, because tools tend to add a fake
// `window` in Node environments which won't actually receive global variables.
if (typeof global !== 'undefined') {
testGlobals = global as {} as TestGlobals;
} else if (typeof window !== 'undefined') {
testGlobals = window as {} as TestGlobals;
} else {
testGlobals = {} as TestGlobals;
}

/** Gets whether the code is currently running in a test environment. */
export function _isTestEnvironment(): boolean {
// We can't use `declare const` because it causes conflicts inside Google with the real typings
// for these symbols and we can't read them off the global object, because they don't appear to
// be attached there for some runners like Jest.
// (see: https://github.com/angular/components/issues/23365#issuecomment-938146643)
return (
(typeof testGlobals.__karma__ !== 'undefined' && !!testGlobals.__karma__) ||
(typeof testGlobals.jasmine !== 'undefined' && !!testGlobals.jasmine) ||
(typeof testGlobals.jest !== 'undefined' && !!testGlobals.jest) ||
(typeof testGlobals.Mocha !== 'undefined' && !!testGlobals.Mocha)
// @ts-ignore
(typeof __karma__ !== 'undefined' && !!__karma__) ||
// @ts-ignore
(typeof jasmine !== 'undefined' && !!jasmine) ||
// @ts-ignore
(typeof jest !== 'undefined' && !!jest) ||
// @ts-ignore
(typeof Mocha !== 'undefined' && !!Mocha)
);
}
2 changes: 1 addition & 1 deletion src/material-experimental/mdc-chips/chip-row.ts
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ export class MatChipRow
* Timeout used to give some time between `focusin` and `focusout`
* in order to determine whether focus has left the chip.
*/
private _focusoutTimeout: any;
private _focusoutTimeout: number | null;

constructor(
@Inject(DOCUMENT) private readonly _document: any,
Expand Down
2 changes: 1 addition & 1 deletion src/material-experimental/mdc-dialog/dialog-container.ts
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ export class MatDialogContainer extends _MatDialogContainerBase implements OnDes
? numbers.DIALOG_ANIMATION_CLOSE_TIME_MS
: 0;
/** Current timer for dialog animations. */
private _animationTimer: any = null;
private _animationTimer: number | null = null;

constructor(
elementRef: ElementRef,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,7 @@ export class MatSnackBarContainer
private readonly _announceDelay: number = 150;

/** The timeout for announcing the snack bar's content. */
private _announceTimeoutId: any;
private _announceTimeoutId: number;

/** Subject for notifying that the snack bar has announced to screen readers. */
readonly _onAnnounce: Subject<void> = new Subject();
Expand Down
2 changes: 1 addition & 1 deletion src/material/bottom-sheet/bottom-sheet-ref.ts
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ export class MatBottomSheetRef<T = any, R = any> {
private _result: R | undefined;

/** Handle to the timeout that's running as a fallback in case the exit animation doesn't fire. */
private _closeFallbackTimeout: any;
private _closeFallbackTimeout: number;

constructor(containerInstance: MatBottomSheetContainer, private _overlayRef: OverlayRef) {
this.containerInstance = containerInstance;
Expand Down
2 changes: 1 addition & 1 deletion src/material/dialog/dialog-ref.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ export class MatDialogRef<T, R = any> {
private _result: R | undefined;

/** Handle to the timeout that's running as a fallback in case the exit animation doesn't fire. */
private _closeFallbackTimeout: any;
private _closeFallbackTimeout: number;

/** Current state of the dialog. */
private _state = MatDialogState.OPEN;
Expand Down
2 changes: 1 addition & 1 deletion src/material/snack-bar/snack-bar-container.ts
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,7 @@ export class MatSnackBarContainer
private readonly _announceDelay: number = 150;

/** The timeout for announcing the snack bar's content. */
private _announceTimeoutId: any;
private _announceTimeoutId: number;

/** Whether the component has been destroyed. */
private _destroyed = false;
Expand Down
2 changes: 1 addition & 1 deletion src/material/snack-bar/snack-bar-ref.ts
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ export class MatSnackBarRef<T> {
* Timeout ID for the duration setTimeout call. Used to clear the timeout if the snackbar is
* dismissed before the duration passes.
*/
private _durationTimeoutId: any;
private _durationTimeoutId: number;

/** Whether the snack bar was dismissed using the action button. */
private _dismissedByAction = false;
Expand Down
6 changes: 3 additions & 3 deletions src/material/tooltip/tooltip.ts
Original file line number Diff line number Diff line change
Expand Up @@ -258,7 +258,7 @@ export abstract class _MatTooltipBase<T extends _TooltipComponentBase>
private _document: Document;

/** Timer started at the last `touchstart` event. */
private _touchstartTimeout: any;
private _touchstartTimeout: number;

/** Emits when the component is destroyed. */
private readonly _destroyed = new Subject<void>();
Expand Down Expand Up @@ -807,10 +807,10 @@ export abstract class _TooltipComponentBase implements OnDestroy {
tooltipClass: string | string[] | Set<string> | {[key: string]: any};

/** The timeout ID of any current timer set to show the tooltip */
_showTimeoutId: any;
_showTimeoutId: number | undefined;

/** The timeout ID of any current timer set to hide the tooltip */
_hideTimeoutId: any;
_hideTimeoutId: number | undefined;

/** Property watched by the animation framework to show or hide the tooltip */
_visibility: TooltipVisibility = 'initial';
Expand Down
2 changes: 1 addition & 1 deletion src/tsconfig-legacy.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
"paths": {
"@angular/*": ["./*"]
},
"types": ["jasmine", "node"],
"types": ["jasmine"],
"emitDecoratorMetadata": true,
"experimentalDecorators": true
},
Expand Down
4 changes: 2 additions & 2 deletions tools/public_api_guard/material/tooltip.md
Original file line number Diff line number Diff line change
Expand Up @@ -183,15 +183,15 @@ export abstract class _TooltipComponentBase implements OnDestroy {
_animationStart(): void;
_handleBodyInteraction(): void;
hide(delay: number): void;
_hideTimeoutId: any;
_hideTimeoutId: number | undefined;
isVisible(): boolean;
_markForCheck(): void;
message: string;
// (undocumented)
ngOnDestroy(): void;
protected _onShow(): void;
show(delay: number): void;
_showTimeoutId: any;
_showTimeoutId: number | undefined;
tooltipClass: string | string[] | Set<string> | {
[key: string]: any;
};
Expand Down

0 comments on commit 2fc63ef

Please sign in to comment.