-
-
Notifications
You must be signed in to change notification settings - Fork 934
/
reportingUpdateCheck.ts
119 lines (103 loc) · 2.64 KB
/
reportingUpdateCheck.ts
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
import { Config } from '@pnpm/config'
import { updateCheckLogger } from '@pnpm/core-loggers'
import { toOutput$ } from '@pnpm/default-reporter'
import { createStreamParser } from '@pnpm/logger'
import { take } from 'rxjs/operators'
import stripAnsi from 'strip-ansi'
test('does not print update if latest is less than current', (done) => {
const output$ = toOutput$({
context: {
argv: ['install'],
env: {},
},
streamParser: createStreamParser(),
})
updateCheckLogger.debug({
currentVersion: '10.0.0',
latestVersion: '9.0.0',
})
const subscription = output$.subscribe({
complete: () => done(),
error: done,
next: () => {
done('should not log anything')
},
})
setTimeout(() => {
done()
subscription.unsubscribe()
}, 10)
})
test('print update notification if the latest version is greater than the current', (done) => {
const output$ = toOutput$({
context: {
argv: ['install'],
config: { recursive: true } as Config,
env: {},
},
streamParser: createStreamParser(),
})
updateCheckLogger.debug({
currentVersion: '10.0.0',
latestVersion: '11.0.0',
})
expect.assertions(1)
output$.pipe(take(1)).subscribe({
complete: () => done(),
error: done,
next: output => {
expect(stripAnsi(output)).toMatchSnapshot()
},
})
})
test('print update notification for Corepack if the latest version is greater than the current', (done) => {
const output$ = toOutput$({
context: {
argv: ['install'],
config: { recursive: true } as Config,
env: {
COREPACK_ROOT: '/usr/bin/corepack',
},
},
streamParser: createStreamParser(),
})
updateCheckLogger.debug({
currentVersion: '10.0.0',
latestVersion: '11.0.0',
})
expect.assertions(1)
output$.pipe(take(1)).subscribe({
complete: () => done(),
error: done,
next: output => {
expect(stripAnsi(output)).toMatchSnapshot()
},
})
})
test('print update notification that suggests to use the standalone scripts for the upgrade', (done) => {
const output$ = toOutput$({
context: {
argv: ['install'],
config: { recursive: true } as Config,
env: {
PNPM_HOME: '/home/user/.local/share/pnpm',
},
process: {
pkg: true,
} as any, // eslint-disable-line
},
streamParser: createStreamParser(),
})
updateCheckLogger.debug({
currentVersion: '10.0.0',
latestVersion: '11.0.0',
})
expect.assertions(1)
output$.pipe(take(1)).subscribe({
complete: () => done(),
error: done,
next: output => {
expect(stripAnsi(output)).toMatchSnapshot()
},
})
})