-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathtsconfig.json
49 lines (44 loc) · 3.52 KB
/
tsconfig.json
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
{
"compilerOptions": {
// Language and Environment
"target": "es6", // ECMAScript(Javascript) target version to which the TypeScript code is compiled
// Modules
"module": "commonjs",
"baseUrl": ".", // Sets a base directory to resolve non-relative module names. Simplifying import paths in a project
"moduleResolution": "node", // Uses Node.js logic for traversing the directory tree to find the modules
"resolveJsonModule": true, // Allows importing JSON files and accessing the data through 'import'
"paths": {
"@pages/*": ["tests/pages/*", "examples/sauce-demo-tests-using-functions/pages/*"],
"@testdata/*": ["tests/testdata/*"],
"@fixturesetup": ["tests/fixtures/testFixtures"],
"@pagesetup": ["test-setup/page-setup"],
"@playwright-config": ["playwright.config"]
}, // Sets up custom path mappings, enabling to import modules with convenient shorter paths
// Emit
"outDir": "dist", // Directory where compiled JavaScript files are placed after TypeScript compilation
"sourceMap": true, // Generates a source map files along with the compiled JavaScript files
"declaration": false, // No need to generate declaration files (.d.ts) for a test project
"declarationMap": false, // No need to generate sourcemap for each corresponding '.d.ts' file
"importHelpers": true, // Allows the TypeScript compiler to import helper functions from the tslib module
// Interop Constraints
"esModuleInterop": true, // Enhances interoperability and consistency in handling module imports and exports
"forceConsistentCasingInFileNames": true, // Enforces that the casing of the file path used in import statements and references matches the actual casing of the file
// Type Checking
"noImplicitOverride": true, // Ensures that overriding methods in a subclass are marked with the 'override' keyword
"noImplicitReturns": true, // Ensures that all code paths in a function explicitly return a value
"noFallthroughCasesInSwitch": true, // Prevents code from 'falling through' from one case in a switch statement to another
"noUnusedLocals": true, // Compiler reports an error if a local variable is declared but not used in the function
"noUnusedParameters": true, // Compiler reports an error if a function contains parameters that are declared but not used
"strictPropertyInitialization": true, // Ensures that each property declared in a class gets initialized either in constructor or by a default value
"strict": true, // Enables a stricter type-checking mode and activates a range of type-checking complier options to catch potential issues early in the development process
// With above 'strict' option set to True, all the below strict options are activated to true by default
// Explicit mention here is to update these options as per your project needs
"strictNullChecks": true, // Enforces proper handling of null and undefined values to prevent common null-reference errors
"strictBindCallApply": true, // Provides checks on the use of functions like bind, call, and apply
"strictFunctionTypes": true, // Enforces checking of function types, particularly related to contravariant parameter types
// Completeness
"skipLibCheck": true // Skips the type checking of '.d.ts' files for faster compilation times
},
"include": ["tests/**/*.ts", "playwright.config.ts", ".eslintrc.js"],
"exclude": ["node_modules"] // Node_modules are excluded by default, but explicitly specified here for further exclusions as needed in your project
}