-
Notifications
You must be signed in to change notification settings - Fork 3.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
chore: Open in IDE button for block and hook definitions in Runner UI #30859
Changes from all commits
237c825
6106400
877d8b2
c92a883
84519d6
d99c450
f137526
6cedebc
c6c9d28
edd10e7
21a757e
921d67f
f406080
da40a47
e06a2c4
03c0865
6d580b0
b3018b4
6c2ded8
30d0f45
cc42d8c
475fbfa
d0d7993
bce0e55
0c38ce9
4996e11
2234703
15ed6aa
b5490b3
f70871b
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Large diffs are not rendered by default.
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
/** | ||
* @vitest-environment jsdom | ||
*/ | ||
import { vi, describe, it, expect, beforeEach } from 'vitest' | ||
|
||
import source_map_utils from '../../../src/cypress/source_map_utils' | ||
import stack_utils from '../../../src/cypress/stack_utils' | ||
import stackFrameFixture from './__fixtures__/spec_stackframes.json' | ||
|
||
vi.mock('../../../src/cypress/source_map_utils', () => { | ||
return { | ||
default: { | ||
getSourcePosition: vi.fn(), | ||
}, | ||
} | ||
}) | ||
|
||
describe('stack_utils', () => { | ||
beforeEach(() => { | ||
// @ts-expect-error | ||
global.Cypress = { | ||
config: vi.fn(), | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The results of this function call are inconsequential to the logic under test, but the lack of a global |
||
} | ||
|
||
vi.resetAllMocks() | ||
}) | ||
|
||
describe('getInvocationDetails', () => { | ||
const { line, column, scenarios } = stackFrameFixture | ||
|
||
const projectRoot = '/foo/bar' | ||
|
||
let stack: string | ||
|
||
class MockError { | ||
get stack () { | ||
return stack | ||
} | ||
} | ||
const config = () => projectRoot | ||
|
||
for (const scenario of scenarios) { | ||
const { browser, build, specFrame, stack: scenarioStack } = scenario | ||
|
||
describe(`${browser}:${build}`, () => { | ||
beforeEach(() => { | ||
stack = scenarioStack | ||
}) | ||
|
||
it('calls getSourcePosition with the correct file, line, and column', () => { | ||
stack_utils.getInvocationDetails( | ||
{ Error: MockError, Cypress: {} }, | ||
config, | ||
) | ||
|
||
// getSourcePosition is not called directly from getInvocationDetails, but via: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This indirect call of the spied upon function does introduce brittleness to this test. It will not pass if the underlying implementation is changed. We should consider refactoring stack analysis, especially for user invocation codepoints, to standard patterns to ease testing flexibility. |
||
// - getSourceDetailsForFirstLine | ||
// - getSourceDetailsForLine | ||
expect(source_map_utils.getSourcePosition).toHaveBeenCalledWith(specFrame, expect.objectContaining({ | ||
column, | ||
line, | ||
file: specFrame, | ||
})) | ||
}) | ||
}) | ||
} | ||
}) | ||
}) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
import { defineConfig } from 'vitest/config' | ||
|
||
export default defineConfig({ | ||
test: { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
|
||
include: ['test/unit/**/*.spec.ts'], | ||
environment: 'jsdom', | ||
exclude: ['**/__fixtures__/**/*'], | ||
reporters: [ | ||
'default', | ||
['junit', { suiteName: 'Driver Unit Tests', outputFile: '/tmp/cypress/junit/driver-test-results.xml' }], | ||
], | ||
}, | ||
}) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This could have been left unmocked, with the return value of
getInvocationDetails
asserted upon, howeversource_map_utils
imports a.wasm
dependency which vitest could not handle (even withvite-plugin-wasm
included). It was more expedient to mock out the entire module.