2024-03-06 18:34:07 +03:00
|
|
|
import { test, type Page } from '@playwright/test'
|
2024-01-18 16:45:18 +03:00
|
|
|
import * as actions from './actions'
|
2024-03-06 18:34:07 +03:00
|
|
|
import { expect } from './customExpect'
|
2024-01-18 16:45:18 +03:00
|
|
|
import { mockCollapsedFunctionInfo } from './expressionUpdates'
|
2024-04-19 19:33:51 +03:00
|
|
|
import { CONTROL_KEY } from './keyboard'
|
2024-01-18 16:45:18 +03:00
|
|
|
import * as locate from './locate'
|
2024-11-26 20:37:57 +03:00
|
|
|
import { edgesFromNode, edgesToNode } from './locate'
|
2024-08-28 14:05:19 +03:00
|
|
|
import { mockSuggestion } from './suggestionUpdates'
|
2024-01-18 16:45:18 +03:00
|
|
|
|
2024-04-24 14:40:42 +03:00
|
|
|
const MAIN_FILE_NODES = 12
|
2024-11-26 20:37:57 +03:00
|
|
|
const EDGE_PARTS = 2
|
2024-03-25 19:05:20 +03:00
|
|
|
|
2024-04-19 19:33:51 +03:00
|
|
|
const COLLAPSE_SHORTCUT = `${CONTROL_KEY}+G`
|
2024-01-18 16:45:18 +03:00
|
|
|
|
|
|
|
test('Entering nodes', async ({ page }) => {
|
|
|
|
await actions.goToGraph(page)
|
|
|
|
await mockCollapsedFunctionInfo(page, 'final', 'func1')
|
|
|
|
await expectInsideMain(page)
|
2024-02-23 16:48:33 +03:00
|
|
|
await expect(locate.navBreadcrumb(page)).toHaveText(['Mock Project'])
|
2024-01-18 16:45:18 +03:00
|
|
|
|
|
|
|
await locate.graphNodeByBinding(page, 'final').dblclick()
|
|
|
|
await mockCollapsedFunctionInfo(page, 'f2', 'func2')
|
|
|
|
await expectInsideFunc1(page)
|
2024-02-23 16:48:33 +03:00
|
|
|
await expect(locate.navBreadcrumb(page)).toHaveText(['Mock Project', 'func1'])
|
2024-01-18 16:45:18 +03:00
|
|
|
|
|
|
|
await locate.graphNodeByBinding(page, 'f2').dblclick()
|
|
|
|
await expectInsideFunc2(page)
|
2024-02-23 16:48:33 +03:00
|
|
|
await expect(locate.navBreadcrumb(page)).toHaveText(['Mock Project', 'func1', 'func2'])
|
2024-01-18 16:45:18 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
test('Leaving entered nodes', async ({ page }) => {
|
|
|
|
await actions.goToGraph(page)
|
|
|
|
await enterToFunc2(page)
|
|
|
|
|
2024-03-06 18:34:07 +03:00
|
|
|
await actions.exitFunction(page)
|
2024-01-18 16:45:18 +03:00
|
|
|
await expectInsideFunc1(page)
|
|
|
|
|
2024-03-06 18:34:07 +03:00
|
|
|
await actions.exitFunction(page)
|
2024-01-18 16:45:18 +03:00
|
|
|
await expectInsideMain(page)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('Using breadcrumbs to navigate', async ({ page }) => {
|
|
|
|
await actions.goToGraph(page)
|
|
|
|
await enterToFunc2(page)
|
2024-03-06 18:34:07 +03:00
|
|
|
await actions.exitFunction(page)
|
Fix interfering click handlers (#9127)
Fixes one failure in #8942 which caught a real issue: clicks at various panels were triggering many handlers at once, often unexpectedly - for example quick clicking at breadcrumbs (and automatic tests always click fast) we could also trigger getting out the current node.
Therefore, I added `stopPropagation` for all mouse events on "panel" level + where I think the event should be considered "handled" and no longer bother anyone. Also, to unify things, most actions are for `click` event.
Additionally I spotted and fixed some issues:
* When "clicking-off" Component Browser, it creates new node only if anything was actually typed in (no more dangling `operatorX.` nodes)
* Filtering now works for operators
* When, after opening CB with source node, user starts typing operator, we replace dot with space
* Fixed our shortcut handler, so it works properly with `click` event.
* Fixed problems with defocusing input in CB when clicking at links.
# Important Notes
I removed `PointerMain` binding for deselectAll, because it was triggered every time did the area selection.
2024-02-22 18:18:28 +03:00
|
|
|
await expectInsideFunc1(page)
|
2024-03-06 18:34:07 +03:00
|
|
|
await actions.exitFunction(page)
|
Fix interfering click handlers (#9127)
Fixes one failure in #8942 which caught a real issue: clicks at various panels were triggering many handlers at once, often unexpectedly - for example quick clicking at breadcrumbs (and automatic tests always click fast) we could also trigger getting out the current node.
Therefore, I added `stopPropagation` for all mouse events on "panel" level + where I think the event should be considered "handled" and no longer bother anyone. Also, to unify things, most actions are for `click` event.
Additionally I spotted and fixed some issues:
* When "clicking-off" Component Browser, it creates new node only if anything was actually typed in (no more dangling `operatorX.` nodes)
* Filtering now works for operators
* When, after opening CB with source node, user starts typing operator, we replace dot with space
* Fixed our shortcut handler, so it works properly with `click` event.
* Fixed problems with defocusing input in CB when clicking at links.
# Important Notes
I removed `PointerMain` binding for deselectAll, because it was triggered every time did the area selection.
2024-02-22 18:18:28 +03:00
|
|
|
await expectInsideMain(page)
|
2024-01-18 16:45:18 +03:00
|
|
|
// Breadcrumbs still have all the crumbs, but the last two are dimmed.
|
2024-02-23 16:48:33 +03:00
|
|
|
await expect(locate.navBreadcrumb(page)).toHaveText(['Mock Project', 'func1', 'func2'])
|
2024-10-11 21:23:02 +03:00
|
|
|
await expect(locate.navBreadcrumb(page).and(page.locator('.inactive'))).toHaveText([
|
2024-01-18 16:45:18 +03:00
|
|
|
'func1',
|
|
|
|
'func2',
|
|
|
|
])
|
|
|
|
|
2024-01-29 13:53:44 +03:00
|
|
|
await locate.navBreadcrumb(page).filter({ hasText: 'func2' }).click()
|
|
|
|
await expectInsideFunc2(page)
|
|
|
|
|
2024-02-23 16:48:33 +03:00
|
|
|
await locate.navBreadcrumb(page).filter({ hasText: 'Mock Project' }).click()
|
2024-01-29 13:53:44 +03:00
|
|
|
await expectInsideMain(page)
|
|
|
|
|
|
|
|
await locate.navBreadcrumb(page).filter({ hasText: 'func1' }).click()
|
|
|
|
await expectInsideFunc1(page)
|
2024-01-18 16:45:18 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
test('Collapsing nodes', async ({ page }) => {
|
|
|
|
await actions.goToGraph(page)
|
2024-01-26 20:18:27 +03:00
|
|
|
const initialNodesCount = await locate.graphNode(page).count()
|
2024-01-18 16:45:18 +03:00
|
|
|
await mockCollapsedFunctionInfo(page, 'final', 'func1')
|
|
|
|
|
Fix interfering click handlers (#9127)
Fixes one failure in #8942 which caught a real issue: clicks at various panels were triggering many handlers at once, often unexpectedly - for example quick clicking at breadcrumbs (and automatic tests always click fast) we could also trigger getting out the current node.
Therefore, I added `stopPropagation` for all mouse events on "panel" level + where I think the event should be considered "handled" and no longer bother anyone. Also, to unify things, most actions are for `click` event.
Additionally I spotted and fixed some issues:
* When "clicking-off" Component Browser, it creates new node only if anything was actually typed in (no more dangling `operatorX.` nodes)
* Filtering now works for operators
* When, after opening CB with source node, user starts typing operator, we replace dot with space
* Fixed our shortcut handler, so it works properly with `click` event.
* Fixed problems with defocusing input in CB when clicking at links.
# Important Notes
I removed `PointerMain` binding for deselectAll, because it was triggered every time did the area selection.
2024-02-22 18:18:28 +03:00
|
|
|
// Widgets may "steal" clicks, so we always click at icon.
|
|
|
|
await locate
|
2024-03-08 22:00:39 +03:00
|
|
|
.graphNodeByBinding(page, 'prod')
|
2024-07-12 13:45:57 +03:00
|
|
|
.locator('.grab-handle')
|
Fix interfering click handlers (#9127)
Fixes one failure in #8942 which caught a real issue: clicks at various panels were triggering many handlers at once, often unexpectedly - for example quick clicking at breadcrumbs (and automatic tests always click fast) we could also trigger getting out the current node.
Therefore, I added `stopPropagation` for all mouse events on "panel" level + where I think the event should be considered "handled" and no longer bother anyone. Also, to unify things, most actions are for `click` event.
Additionally I spotted and fixed some issues:
* When "clicking-off" Component Browser, it creates new node only if anything was actually typed in (no more dangling `operatorX.` nodes)
* Filtering now works for operators
* When, after opening CB with source node, user starts typing operator, we replace dot with space
* Fixed our shortcut handler, so it works properly with `click` event.
* Fixed problems with defocusing input in CB when clicking at links.
# Important Notes
I removed `PointerMain` binding for deselectAll, because it was triggered every time did the area selection.
2024-02-22 18:18:28 +03:00
|
|
|
.click({ modifiers: ['Shift'] })
|
|
|
|
await locate
|
|
|
|
.graphNodeByBinding(page, 'sum')
|
2024-07-12 13:45:57 +03:00
|
|
|
.locator('.grab-handle')
|
Fix interfering click handlers (#9127)
Fixes one failure in #8942 which caught a real issue: clicks at various panels were triggering many handlers at once, often unexpectedly - for example quick clicking at breadcrumbs (and automatic tests always click fast) we could also trigger getting out the current node.
Therefore, I added `stopPropagation` for all mouse events on "panel" level + where I think the event should be considered "handled" and no longer bother anyone. Also, to unify things, most actions are for `click` event.
Additionally I spotted and fixed some issues:
* When "clicking-off" Component Browser, it creates new node only if anything was actually typed in (no more dangling `operatorX.` nodes)
* Filtering now works for operators
* When, after opening CB with source node, user starts typing operator, we replace dot with space
* Fixed our shortcut handler, so it works properly with `click` event.
* Fixed problems with defocusing input in CB when clicking at links.
# Important Notes
I removed `PointerMain` binding for deselectAll, because it was triggered every time did the area selection.
2024-02-22 18:18:28 +03:00
|
|
|
.click({ modifiers: ['Shift'] })
|
|
|
|
await locate
|
2024-03-08 22:00:39 +03:00
|
|
|
.graphNodeByBinding(page, 'ten')
|
2024-07-12 13:45:57 +03:00
|
|
|
.locator('.grab-handle')
|
Fix interfering click handlers (#9127)
Fixes one failure in #8942 which caught a real issue: clicks at various panels were triggering many handlers at once, often unexpectedly - for example quick clicking at breadcrumbs (and automatic tests always click fast) we could also trigger getting out the current node.
Therefore, I added `stopPropagation` for all mouse events on "panel" level + where I think the event should be considered "handled" and no longer bother anyone. Also, to unify things, most actions are for `click` event.
Additionally I spotted and fixed some issues:
* When "clicking-off" Component Browser, it creates new node only if anything was actually typed in (no more dangling `operatorX.` nodes)
* Filtering now works for operators
* When, after opening CB with source node, user starts typing operator, we replace dot with space
* Fixed our shortcut handler, so it works properly with `click` event.
* Fixed problems with defocusing input in CB when clicking at links.
# Important Notes
I removed `PointerMain` binding for deselectAll, because it was triggered every time did the area selection.
2024-02-22 18:18:28 +03:00
|
|
|
.click({ modifiers: ['Shift'] })
|
2024-01-18 16:45:18 +03:00
|
|
|
|
2024-06-07 04:48:11 +03:00
|
|
|
await page.getByLabel('Group Selected Components').click()
|
2024-01-26 20:18:27 +03:00
|
|
|
await expect(locate.graphNode(page)).toHaveCount(initialNodesCount - 2)
|
2024-01-18 16:45:18 +03:00
|
|
|
await mockCollapsedFunctionInfo(page, 'prod', 'collapsed')
|
2024-08-28 14:05:19 +03:00
|
|
|
await mockSuggestion(page, {
|
|
|
|
type: 'method',
|
|
|
|
module: 'local.Mock_Project',
|
|
|
|
name: 'collapsed',
|
|
|
|
isStatic: true,
|
|
|
|
arguments: [{ name: 'five', reprType: 'Any', isSuspended: false, hasDefault: false }],
|
|
|
|
selfType: 'local.Mock_Project',
|
|
|
|
returnType: 'Standard.Base.Any.Any',
|
|
|
|
annotations: [],
|
|
|
|
})
|
|
|
|
const collapsedNode = locate.graphNodeByBinding(page, 'prod')
|
2024-12-05 21:03:48 +03:00
|
|
|
await expect(collapsedNode.locator('.WidgetApplication.prefix > .WidgetPort')).toExist()
|
|
|
|
await expect(collapsedNode.locator('.WidgetApplication.prefix > .WidgetPort')).toHaveText(
|
|
|
|
'Main.collapsed',
|
|
|
|
)
|
2024-08-28 14:05:19 +03:00
|
|
|
await expect(collapsedNode.locator('.WidgetTopLevelArgument')).toHaveText('five')
|
2024-01-18 16:45:18 +03:00
|
|
|
|
2024-05-22 18:07:39 +03:00
|
|
|
await locate.graphNodeIcon(collapsedNode).dblclick()
|
2024-10-01 00:20:08 +03:00
|
|
|
await expect(locate.graphNode(page)).toHaveCount(5)
|
|
|
|
await expect(locate.inputNode(page)).toHaveCount(1)
|
2024-03-06 18:34:07 +03:00
|
|
|
await expect(locate.graphNodeByBinding(page, 'ten')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'sum')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'prod')).toExist()
|
2024-03-05 10:06:11 +03:00
|
|
|
await locate
|
Fix interfering click handlers (#9127)
Fixes one failure in #8942 which caught a real issue: clicks at various panels were triggering many handlers at once, often unexpectedly - for example quick clicking at breadcrumbs (and automatic tests always click fast) we could also trigger getting out the current node.
Therefore, I added `stopPropagation` for all mouse events on "panel" level + where I think the event should be considered "handled" and no longer bother anyone. Also, to unify things, most actions are for `click` event.
Additionally I spotted and fixed some issues:
* When "clicking-off" Component Browser, it creates new node only if anything was actually typed in (no more dangling `operatorX.` nodes)
* Filtering now works for operators
* When, after opening CB with source node, user starts typing operator, we replace dot with space
* Fixed our shortcut handler, so it works properly with `click` event.
* Fixed problems with defocusing input in CB when clicking at links.
# Important Notes
I removed `PointerMain` binding for deselectAll, because it was triggered every time did the area selection.
2024-02-22 18:18:28 +03:00
|
|
|
.graphNodeByBinding(page, 'ten')
|
2024-07-12 13:45:57 +03:00
|
|
|
.locator('.grab-handle')
|
Fix interfering click handlers (#9127)
Fixes one failure in #8942 which caught a real issue: clicks at various panels were triggering many handlers at once, often unexpectedly - for example quick clicking at breadcrumbs (and automatic tests always click fast) we could also trigger getting out the current node.
Therefore, I added `stopPropagation` for all mouse events on "panel" level + where I think the event should be considered "handled" and no longer bother anyone. Also, to unify things, most actions are for `click` event.
Additionally I spotted and fixed some issues:
* When "clicking-off" Component Browser, it creates new node only if anything was actually typed in (no more dangling `operatorX.` nodes)
* Filtering now works for operators
* When, after opening CB with source node, user starts typing operator, we replace dot with space
* Fixed our shortcut handler, so it works properly with `click` event.
* Fixed problems with defocusing input in CB when clicking at links.
# Important Notes
I removed `PointerMain` binding for deselectAll, because it was triggered every time did the area selection.
2024-02-22 18:18:28 +03:00
|
|
|
.click({ modifiers: ['Shift'] })
|
2024-01-18 16:45:18 +03:00
|
|
|
// Wait till node is selected.
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'ten').and(page.locator('.selected'))).toHaveCount(1)
|
|
|
|
await page.keyboard.press(COLLAPSE_SHORTCUT)
|
2024-10-01 00:20:08 +03:00
|
|
|
await expect(locate.graphNode(page)).toHaveCount(5)
|
|
|
|
await expect(locate.inputNode(page)).toHaveCount(1)
|
2024-01-18 16:45:18 +03:00
|
|
|
|
|
|
|
const secondCollapsedNode = locate.graphNodeByBinding(page, 'ten')
|
|
|
|
await expect(secondCollapsedNode.locator('.WidgetToken')).toHaveText(['Main', '.', 'collapsed1'])
|
|
|
|
await mockCollapsedFunctionInfo(page, 'ten', 'collapsed1')
|
2024-02-06 12:43:38 +03:00
|
|
|
await secondCollapsedNode.dblclick()
|
2024-01-18 16:45:18 +03:00
|
|
|
await expect(locate.graphNode(page)).toHaveCount(2)
|
2024-03-06 18:34:07 +03:00
|
|
|
await expect(locate.graphNodeByBinding(page, 'ten')).toExist()
|
2024-01-18 16:45:18 +03:00
|
|
|
})
|
|
|
|
|
2024-10-01 00:20:08 +03:00
|
|
|
test('Input node', async ({ page }) => {
|
|
|
|
await actions.goToGraph(page)
|
|
|
|
await enterToFunc2(page)
|
|
|
|
|
|
|
|
const inputNode = locate.inputNode(page)
|
|
|
|
await expect(inputNode).toHaveCount(1)
|
|
|
|
// Input node with identifier should have the icon and an identifier.
|
|
|
|
await expect(inputNode.locator('.WidgetIcon')).toHaveCount(1)
|
|
|
|
await expect(inputNode.locator('.WidgetToken')).toContainText('a')
|
|
|
|
|
|
|
|
await inputNode.click()
|
|
|
|
await page.keyboard.press('Delete')
|
|
|
|
await expect(inputNode).toHaveCount(1)
|
|
|
|
await inputNode.locator('.More').click({})
|
|
|
|
await expect(inputNode.getByTestId('removeNode')).toHaveClass(/(?<=^| )disabled(?=$| )/)
|
|
|
|
})
|
|
|
|
|
2024-07-19 14:50:14 +03:00
|
|
|
test('Output node', async ({ page }) => {
|
|
|
|
await actions.goToGraph(page)
|
|
|
|
await enterToFunc2(page)
|
|
|
|
|
|
|
|
const outputNode = locate.outputNode(page)
|
|
|
|
await expect(outputNode).toHaveCount(1)
|
|
|
|
// Output node with identifier should have only icon and no displayed identifiers
|
2024-07-25 17:26:29 +03:00
|
|
|
await expect(outputNode.locator('.WidgetIcon')).toHaveCount(1)
|
2024-07-19 14:50:14 +03:00
|
|
|
await expect(outputNode.locator('.WidgetToken')).toHaveCount(0)
|
|
|
|
|
|
|
|
await outputNode.click()
|
|
|
|
await page.keyboard.press('Delete')
|
|
|
|
await expect(outputNode).toHaveCount(1)
|
|
|
|
await outputNode.locator('.More').click({})
|
|
|
|
await expect(outputNode.getByTestId('removeNode')).toHaveClass(/(?<=^| )disabled(?=$| )/)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('Output node is not collapsed', async ({ page }) => {
|
|
|
|
await actions.goToGraph(page)
|
|
|
|
await enterToFunc2(page)
|
|
|
|
|
2024-10-01 00:20:08 +03:00
|
|
|
await locate.outputNode(page).click({ modifiers: ['Shift'] })
|
2024-07-19 14:50:14 +03:00
|
|
|
await locate
|
|
|
|
.graphNodeByBinding(page, 'r')
|
|
|
|
.locator('.grab-handle')
|
|
|
|
.click({ modifiers: ['Shift'] })
|
2024-10-01 00:20:08 +03:00
|
|
|
|
|
|
|
await page.getByLabel('Group Selected Components').click()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'r').locator('.WidgetToken')).toHaveText([
|
|
|
|
'Main',
|
|
|
|
'.',
|
|
|
|
'collapsed',
|
|
|
|
'a',
|
|
|
|
])
|
|
|
|
await expect(locate.inputNode(page)).toHaveCount(1)
|
|
|
|
})
|
|
|
|
|
|
|
|
test('Input node is not collapsed', async ({ page }) => {
|
|
|
|
await actions.goToGraph(page)
|
|
|
|
await enterToFunc2(page)
|
|
|
|
|
|
|
|
await locate
|
|
|
|
.graphNodeByBinding(page, 'r')
|
|
|
|
.locator('.grab-handle')
|
|
|
|
.click({ modifiers: ['Shift'] })
|
|
|
|
await locate.inputNode(page).click({ modifiers: ['Shift'] })
|
2024-07-19 14:50:14 +03:00
|
|
|
|
|
|
|
await page.getByLabel('Group Selected Components').click()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'r').locator('.WidgetToken')).toHaveText([
|
|
|
|
'Main',
|
|
|
|
'.',
|
|
|
|
'collapsed',
|
|
|
|
'a',
|
|
|
|
])
|
|
|
|
await expect(locate.outputNode(page)).toHaveCount(1)
|
|
|
|
})
|
|
|
|
|
2024-01-18 16:45:18 +03:00
|
|
|
async function expectInsideMain(page: Page) {
|
2024-10-01 00:20:08 +03:00
|
|
|
await actions.expectNodePositionsInitialized(page, -16)
|
2024-03-25 19:05:20 +03:00
|
|
|
await expect(locate.graphNode(page)).toHaveCount(MAIN_FILE_NODES)
|
2024-03-06 18:34:07 +03:00
|
|
|
await expect(locate.graphNodeByBinding(page, 'five')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'ten')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'sum')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'prod')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'final')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'list')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'data')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'aggregated')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'filtered')).toExist()
|
2024-04-24 14:40:42 +03:00
|
|
|
await expect(locate.graphNodeByBinding(page, 'autoscoped')).toExist()
|
2024-01-18 16:45:18 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
async function expectInsideFunc1(page: Page) {
|
2024-10-01 00:20:08 +03:00
|
|
|
await actions.expectNodePositionsInitialized(page, -88)
|
|
|
|
await expect(locate.graphNode(page)).toHaveCount(4)
|
|
|
|
await expect(locate.inputNode(page)).toHaveCount(1)
|
2024-03-06 18:34:07 +03:00
|
|
|
await expect(locate.graphNodeByBinding(page, 'f2')).toExist()
|
|
|
|
await expect(locate.graphNodeByBinding(page, 'result')).toExist()
|
2024-07-19 14:50:14 +03:00
|
|
|
await expect(locate.outputNode(page)).toHaveCount(1)
|
2024-11-26 20:37:57 +03:00
|
|
|
await expect(await edgesFromNode(page, locate.inputNode(page))).toHaveCount(EDGE_PARTS)
|
|
|
|
await expect(await edgesToNode(page, locate.outputNode(page))).toHaveCount(EDGE_PARTS)
|
2024-01-18 16:45:18 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
async function expectInsideFunc2(page: Page) {
|
2024-10-01 00:20:08 +03:00
|
|
|
await actions.expectNodePositionsInitialized(page, -88)
|
|
|
|
await expect(locate.graphNode(page)).toHaveCount(3)
|
|
|
|
await expect(locate.inputNode(page)).toHaveCount(1)
|
2024-03-06 18:34:07 +03:00
|
|
|
await expect(locate.graphNodeByBinding(page, 'r')).toExist()
|
2024-07-19 14:50:14 +03:00
|
|
|
await expect(locate.outputNode(page)).toHaveCount(1)
|
2024-11-26 20:37:57 +03:00
|
|
|
await expect(await edgesFromNode(page, locate.inputNode(page))).toHaveCount(EDGE_PARTS)
|
|
|
|
await expect(await edgesToNode(page, locate.outputNode(page))).toHaveCount(EDGE_PARTS)
|
2024-01-18 16:45:18 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
async function enterToFunc2(page: Page) {
|
|
|
|
await mockCollapsedFunctionInfo(page, 'final', 'func1')
|
|
|
|
await locate.graphNodeByBinding(page, 'final').dblclick()
|
Fix interfering click handlers (#9127)
Fixes one failure in #8942 which caught a real issue: clicks at various panels were triggering many handlers at once, often unexpectedly - for example quick clicking at breadcrumbs (and automatic tests always click fast) we could also trigger getting out the current node.
Therefore, I added `stopPropagation` for all mouse events on "panel" level + where I think the event should be considered "handled" and no longer bother anyone. Also, to unify things, most actions are for `click` event.
Additionally I spotted and fixed some issues:
* When "clicking-off" Component Browser, it creates new node only if anything was actually typed in (no more dangling `operatorX.` nodes)
* Filtering now works for operators
* When, after opening CB with source node, user starts typing operator, we replace dot with space
* Fixed our shortcut handler, so it works properly with `click` event.
* Fixed problems with defocusing input in CB when clicking at links.
# Important Notes
I removed `PointerMain` binding for deselectAll, because it was triggered every time did the area selection.
2024-02-22 18:18:28 +03:00
|
|
|
await expectInsideFunc1(page)
|
2024-01-18 16:45:18 +03:00
|
|
|
await mockCollapsedFunctionInfo(page, 'f2', 'func2')
|
|
|
|
await locate.graphNodeByBinding(page, 'f2').dblclick()
|
Fix interfering click handlers (#9127)
Fixes one failure in #8942 which caught a real issue: clicks at various panels were triggering many handlers at once, often unexpectedly - for example quick clicking at breadcrumbs (and automatic tests always click fast) we could also trigger getting out the current node.
Therefore, I added `stopPropagation` for all mouse events on "panel" level + where I think the event should be considered "handled" and no longer bother anyone. Also, to unify things, most actions are for `click` event.
Additionally I spotted and fixed some issues:
* When "clicking-off" Component Browser, it creates new node only if anything was actually typed in (no more dangling `operatorX.` nodes)
* Filtering now works for operators
* When, after opening CB with source node, user starts typing operator, we replace dot with space
* Fixed our shortcut handler, so it works properly with `click` event.
* Fixed problems with defocusing input in CB when clicking at links.
# Important Notes
I removed `PointerMain` binding for deselectAll, because it was triggered every time did the area selection.
2024-02-22 18:18:28 +03:00
|
|
|
await expectInsideFunc2(page)
|
2024-01-18 16:45:18 +03:00
|
|
|
}
|