Skip to content

Commit

Permalink
update many dependencies including typescript, fix lint errors, run p…
Browse files Browse the repository at this point in the history
…rettier as lint rule
  • Loading branch information
silesky committed Apr 30, 2022
1 parent 35b3b7c commit 87eb516
Show file tree
Hide file tree
Showing 33 changed files with 685 additions and 495 deletions.
32 changes: 25 additions & 7 deletions .eslintrc
Original file line number Diff line number Diff line change
@@ -1,34 +1,52 @@
{
"ignorePatterns": ["/node_modules/", "/dist/", "/example/", "/e2e-tests/", "/qa/"],
"ignorePatterns": [
"/node_modules/",
"/dist/",
"/example/",
"/e2e-tests/",
"/qa/",
"/*.tmp.*/"
],
"parserOptions": {
"ecmaVersion": 2019
},
"env": {
"node": true
},
"extends": ["eslint:recommended", "prettier"],
"overrides": [
{
"files": ["*.{ts,tsx}"],
"files": [
"*.{ts,tsx}"
],
"parser": "@typescript-eslint/parser",
"parserOptions": {
"project": "./tsconfig.json"
},
"extends": [
"eslint:recommended",
"plugin:@typescript-eslint/eslint-recommended",
"plugin:@typescript-eslint/recommended",
"plugin:@typescript-eslint/recommended-requiring-type-checking",
"prettier/@typescript-eslint"
"plugin:prettier/recommended"
],
"rules": {
"@typescript-eslint/explicit-function-return-type": "off",
"@typescript-eslint/ban-ts-ignore": "off",
"@typescript-eslint/ban-ts-comment": "off",
"@typescript-eslint/no-unused-vars": "off",
"@typescript-eslint/no-explicit-any": "off",
"@typescript-eslint/no-non-null-assertion": "off",
"@typescript-eslint/no-floating-promises": "error",
"@typescript-eslint/require-await": "off",
"@typescript-eslint/no-empty-function": "off"
"@typescript-eslint/no-empty-function": "off",
"@typescript-eslint/ban-types": "off" // TODO: turn on
}
},
{
"files": "*.js",
"extends": [
"eslint:recommended",
"plugin:prettier/recommended"
]
}
]
}
}
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -5,3 +5,4 @@
stats.json
/coverage
e2e-tests/data/requests/*.json
*tmp*
30 changes: 30 additions & 0 deletions .prettierrc.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
module.exports = {
printWidth: 80,
trailingComma: 'es5',
tabWidth: 2,
proseWrap: 'preserve',
semi: true,
arrowParens: 'always',
singleQuote: true,
endOfLine: 'auto',
overrides: [
{
files: '*.json',
options: {
parser: 'json',
},
},
{
files: '*.js',
options: {
parser: 'espree',
},
},
{
files: '*.ts?x',
options: {
parser: 'typescript',
},
},
],
}
1 change: 1 addition & 0 deletions jest.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ module.exports = {
moduleNameMapper: {
'@/(.+)': '<rootdir>/../../src/$1',
},
setupFilesAfterEnv: ['./jest.setup.js'],
globals: {
'ts-jest': {
isolatedModules: true,
Expand Down
5 changes: 5 additions & 0 deletions jest.setup.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
const { TextEncoder, TextDecoder } = require('util')

// fix: "ReferenceError: TextEncoder is not defined" after upgrading JSDOM
global.TextEncoder = TextEncoder
global.TextDecoder = TextDecoder
20 changes: 10 additions & 10 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@
"js-cookie": "^2.2.1",
"node-fetch": "^2.6.7",
"spark-md5": "^3.0.1",
"tslib": "^2.1.0",
"tslib": "^2.4.0",
"unfetch": "^4.1.0"
},
"devDependencies": {
Expand All @@ -73,7 +73,7 @@
"@types/jest-dev-server": "^4.2.0",
"@types/jquery": "^3.5.4",
"@types/js-cookie": "^2.2.6",
"@types/jsdom": "^16.2.5",
"@types/jsdom": "^16.2.14",
"@types/lodash": "^4.14.161",
"@types/md5": "^2.2.0",
"@types/mime": "^2.0.3",
Expand All @@ -84,8 +84,8 @@
"@types/sinon": "^9.0.10",
"@types/spark-md5": "^3.0.2",
"@types/test-listen": "^1.1.0",
"@typescript-eslint/eslint-plugin": "^2.25.0",
"@typescript-eslint/parser": "^2.25.0",
"@typescript-eslint/eslint-plugin": "^5.21.0",
"@typescript-eslint/parser": "^5.21.0",
"@wdio/cli": "^6.10.5",
"@wdio/jasmine-framework": "^6.10.4",
"@wdio/local-runner": "^6.10.5",
Expand All @@ -97,9 +97,9 @@
"compression-webpack-plugin": "^8.0.1",
"concurrently": "^5.3.0",
"delay": "^4.4.0",
"electron": "^11.3.0",
"eslint": "^6.8.0",
"eslint-config-prettier": "^6.10.1",
"eslint": "^8.14.0",
"eslint-config-prettier": "^8.5.0",
"eslint-plugin-prettier": "^4.0.0",
"execa": "^4.1.0",
"express": "^4.17.1",
"flat": "^5.0.2",
Expand All @@ -108,7 +108,7 @@
"jest": "^26.6.3",
"jest-dev-server": "^4.4.0",
"jquery": "^3.5.1",
"jsdom": "^16.4.0",
"jsdom": "^19.0.0",
"lighthouse": "^7.3.0",
"lint-staged": "^10.0.9",
"log-update": "^4.0.0",
Expand All @@ -118,7 +118,7 @@
"np": "^7.5.0",
"p-map": "^4.0.0",
"playwright": "^1.20.0",
"prettier": "^2.0.2",
"prettier": "^2.6.2",
"serve": "^12.0.0",
"serve-handler": "^6.1.3",
"sinon": "^9.2.4",
Expand All @@ -128,7 +128,7 @@
"ts-jest": "^26.4.4",
"ts-loader": "^9.1.1",
"ts-node": "^9.0.0",
"typescript": "^3.8.3",
"typescript": "^4.6.4",
"wdio-chromedriver-service": "^6.0.4",
"webpack": "^5.36.1",
"webpack-bundle-analyzer": "^4.4.2",
Expand Down
8 changes: 4 additions & 4 deletions src/__tests__/csp-detection.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -80,11 +80,11 @@ describe('CSP Detection', () => {
jest.spyOn(console, 'warn').mockImplementationOnce(() => {})

windowSpy.mockImplementation(() => {
return (jsd.window as unknown) as Window & typeof globalThis
return jsd.window as unknown as Window & typeof globalThis
})

documentSpy.mockImplementation(
() => (jsd.window.document as unknown) as Document
() => jsd.window.document as unknown as Document
)
})

Expand Down Expand Up @@ -126,10 +126,10 @@ describe('CSP Detection', () => {

const warnSpy = jest.spyOn(console, 'warn')

await onCSPError(({
await onCSPError({
blockedURI: 'cdn.segment.com',
disposition: 'report',
} as unknown) as SecurityPolicyViolationEvent)
} as unknown as SecurityPolicyViolationEvent)

expect(warnSpy).not.toHaveBeenCalled()
expect(Array.from(document.scripts)).toEqual(ogScripts)
Expand Down
14 changes: 6 additions & 8 deletions src/__tests__/integration.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -652,7 +652,7 @@ describe('addDestinationMiddleware', () => {

const windowSpy = jest.spyOn(global, 'window', 'get')
windowSpy.mockImplementation(
() => (jsd.window as unknown) as Window & typeof globalThis
() => jsd.window as unknown as Window & typeof globalThis
)
})

Expand Down Expand Up @@ -755,16 +755,14 @@ describe('deregister', () => {

const windowSpy = jest.spyOn(global, 'window', 'get')
windowSpy.mockImplementation(
() => (jsd.window as unknown) as Window & typeof globalThis
() => jsd.window as unknown as Window & typeof globalThis
)
})

it('deregisters a plugin given its name', async () => {
const unload = jest.fn(
(): Promise<unknown> => {
return Promise.resolve()
}
)
const unload = jest.fn((): Promise<unknown> => {
return Promise.resolve()
})
xt.unload = unload

const [analytics] = await AnalyticsBrowser.load({
Expand Down Expand Up @@ -932,7 +930,7 @@ describe('.Integrations', () => {

const windowSpy = jest.spyOn(global, 'window', 'get')
windowSpy.mockImplementation(
() => (jsd.window as unknown) as Window & typeof globalThis
() => jsd.window as unknown as Window & typeof globalThis
)
})

Expand Down
2 changes: 1 addition & 1 deletion src/__tests__/query-string.integration.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ describe('queryString', () => {

const windowSpy = jest.spyOn(global, 'window', 'get')
windowSpy.mockImplementation(
() => (jsd.window as unknown) as Window & typeof globalThis
() => jsd.window as unknown as Window & typeof globalThis
)
})

Expand Down
4 changes: 2 additions & 2 deletions src/__tests__/standalone-analytics.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -84,11 +84,11 @@ describe('standalone bundle', () => {
jest.spyOn(console, 'warn').mockImplementationOnce(() => {})

windowSpy.mockImplementation(() => {
return (jsd.window as unknown) as Window & typeof globalThis
return jsd.window as unknown as Window & typeof globalThis
})

documentSpy.mockImplementation(
() => (jsd.window.document as unknown) as Document
() => jsd.window.document as unknown as Document
)
})

Expand Down
4 changes: 2 additions & 2 deletions src/__tests__/standalone-errors.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -73,11 +73,11 @@ describe('standalone bundle', () => {
jest.spyOn(console, 'warn').mockImplementationOnce(() => {})

windowSpy.mockImplementation(() => {
return (jsd.window as unknown) as Window & typeof globalThis
return jsd.window as unknown as Window & typeof globalThis
})

documentSpy.mockImplementation(
() => (jsd.window.document as unknown) as Document
() => jsd.window.document as unknown as Document
)
})

Expand Down
4 changes: 2 additions & 2 deletions src/__tests__/standalone.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -74,11 +74,11 @@ describe('standalone bundle', () => {
jest.spyOn(console, 'warn').mockImplementationOnce(() => {})

windowSpy.mockImplementation(() => {
return (jsd.window as unknown) as Window & typeof globalThis
return jsd.window as unknown as Window & typeof globalThis
})

documentSpy.mockImplementation(
() => (jsd.window.document as unknown) as Document
() => jsd.window.document as unknown as Document
)
})

Expand Down
18 changes: 4 additions & 14 deletions src/analytics.ts
Original file line number Diff line number Diff line change
Expand Up @@ -139,13 +139,8 @@ export class Analytics extends Emitter {
}

async page(...args: PageParams): Promise<DispatchedEvent> {
const [
category,
page,
properties,
options,
callback,
] = resolvePageArguments(...args)
const [category, page, properties, options, callback] =
resolvePageArguments(...args)

const segmentEvent = this.eventFactory.page(
category,
Expand Down Expand Up @@ -226,13 +221,8 @@ export class Analytics extends Emitter {
}

async screen(...args: PageParams): Promise<DispatchedEvent> {
const [
category,
page,
properties,
options,
callback,
] = resolvePageArguments(...args)
const [category, page, properties, options, callback] =
resolvePageArguments(...args)

const segmentEvent = this.eventFactory.screen(
category,
Expand Down
2 changes: 0 additions & 2 deletions src/browser-umd.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,12 @@ import { setVersionType } from './plugins/segmentio/normalize'
if (process.env.ASSET_PATH) {
if (process.env.ASSET_PATH === '/dist/umd/') {
// @ts-ignore
// eslint-disable-next-line @typescript-eslint/camelcase
__webpack_public_path__ = '/dist/umd/'
} else {
const cdn = getCDN()
setGlobalCDNUrl(cdn) // preserving original behavior -- TODO: neccessary?

// @ts-ignore
// eslint-disable-next-line @typescript-eslint/camelcase
__webpack_public_path__ = cdn + '/analytics-next/bundles/'
}
}
Expand Down
2 changes: 1 addition & 1 deletion src/core/context/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@ export class Context implements AbstractContext {
throw new ContextCancelation({ reason: 'Context Cancel' })
}

log(level: LogLevel, message: string, extras?: object): void {
log(level: LogLevel, message: string, extras?: any): void {
this.logger.log(level, message, extras)
}

Expand Down
2 changes: 1 addition & 1 deletion src/core/logger/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ export type LogMessage = {
export default class Logger {
private _logs: LogMessage[] = []

log = (level: LogLevel, message: string, extras?: object): void => {
log = (level: LogLevel, message: string, extras?: any): void => {
const time = new Date()
this._logs.push({
level,
Expand Down
4 changes: 0 additions & 4 deletions src/core/query-string/__tests__/pickPrefix.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,7 @@ import { pickPrefix } from '../pickPrefix'
describe('pickPrefix', () => {
it('strips a single prefix to creates an object', () => {
const traits = pickPrefix('ajs_traits_', {
/* eslint-disable @typescript-eslint/camelcase */
ajs_traits_address: '12-123 St.',
/* eslint-enable @typescript-eslint/camelcase */
})

const output = {
Expand All @@ -17,11 +15,9 @@ describe('pickPrefix', () => {

it('stripts multiple prefixes to create an object', () => {
const traits = pickPrefix('ajs_traits_', {
/* eslint-disable @typescript-eslint/camelcase */
ajs_traits_address: '12-123 St.',
ajs_traits_city: 'Vancouver',
ajs_traits_province: 'BC',
/* eslint-enable @typescript-eslint/camelcase */
})

const output = {
Expand Down
3 changes: 0 additions & 3 deletions src/core/query-string/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ export function queryString(

const calls = []

/* eslint-disable @typescript-eslint/camelcase */
const { ajs_uid, ajs_event, ajs_aid } = params

if (ajs_aid) {
Expand Down Expand Up @@ -50,7 +49,5 @@ export function queryString(
calls.push(analytics.track(event, props))
}

/* eslint-enable @typescript-eslint/camelcase */

return Promise.all(calls)
}
Loading

0 comments on commit 87eb516

Please sign in to comment.