mirror of
https://github.com/OliveTin/OliveTin
synced 2026-05-04 13:10:38 +00:00
151 lines
5.7 KiB
JavaScript
151 lines
5.7 KiB
JavaScript
import { describe, it, before, after } from 'mocha'
|
|
import { expect } from 'chai'
|
|
import { By, until, Condition } from 'selenium-webdriver'
|
|
import {
|
|
getRootAndWait,
|
|
takeScreenshotOnFailure,
|
|
} from '../../lib/elements.js'
|
|
|
|
describe('config: enabledExpression', function () {
|
|
this.timeout(30000) // Increase timeout for async operations
|
|
|
|
before(async function () {
|
|
await runner.start('enabledExpression')
|
|
})
|
|
|
|
after(async () => {
|
|
await runner.stop()
|
|
})
|
|
|
|
afterEach(function () {
|
|
takeScreenshotOnFailure(this.currentTest, webdriver);
|
|
});
|
|
|
|
it('Action with enabledExpression for lights enable the correct action', async function() {
|
|
await getRootAndWait()
|
|
|
|
// Navigate to the Lights Dashboard
|
|
// Use the path with space encoded as %20 - Vue Router should decode it
|
|
await webdriver.get(runner.baseUrl() + '/dashboards/LightDashboard')
|
|
|
|
// Wait for the URL to change and the route to be processed
|
|
await webdriver.wait(new Condition('wait for URL to contain dashboards', async function() {
|
|
const url = await webdriver.getCurrentUrl()
|
|
return url.includes('/dashboards/')
|
|
}), 5000)
|
|
|
|
// Wait for dashboard to load by checking the loaded-dashboard attribute
|
|
// The attribute should be set to the decoded title "LightDashboard"
|
|
await webdriver.wait(new Condition('wait for loaded-dashboard', async function() {
|
|
const body = await webdriver.findElement(By.tagName('body'))
|
|
const attr = await body.getAttribute('loaded-dashboard')
|
|
if (attr) {
|
|
console.log('Current loaded-dashboard attribute:', attr)
|
|
}
|
|
// Accept either decoded or encoded version (component should decode, but handle both)
|
|
return attr === 'LightDashboard'
|
|
}), 10000)
|
|
|
|
// Verify we got the correct dashboard (prefer decoded, but accept encoded)
|
|
const body = await webdriver.findElement(By.tagName('body'))
|
|
const attr = await body.getAttribute('loaded-dashboard')
|
|
if (attr !== 'LightDashboard') {
|
|
const currentUrl = await webdriver.getCurrentUrl()
|
|
throw new Error(`Dashboard not loaded correctly. Expected "LightDashboard", got "${attr}". Current URL: ${currentUrl}`)
|
|
}
|
|
|
|
// Wait for dashboard content to appear - check for dashboard rows first
|
|
await webdriver.wait(until.elementsLocated(By.css('.dashboard-row')), 5000)
|
|
|
|
// Debug: Check what's on the page
|
|
const dashboardRows = await webdriver.findElements(By.css('.dashboard-row'))
|
|
console.log(`Found ${dashboardRows.length} dashboard rows`)
|
|
|
|
for (let i = 0; i < dashboardRows.length; i++) {
|
|
const row = dashboardRows[i]
|
|
const h2Elements = await row.findElements(By.css('h2'))
|
|
if (h2Elements.length > 0) {
|
|
const h2Text = await h2Elements[0].getText()
|
|
console.log(`Row ${i} h2: "${h2Text}"`)
|
|
}
|
|
const fieldsets = await row.findElements(By.css('fieldset'))
|
|
console.log(`Row ${i} has ${fieldsets.length} fieldsets`)
|
|
if (fieldsets.length > 0) {
|
|
const buttons = await fieldsets[0].findElements(By.css('.action-button button'))
|
|
console.log(`Row ${i} fieldset has ${buttons.length} buttons`)
|
|
}
|
|
}
|
|
|
|
// Find buttons by looking within entity fieldsets
|
|
// Both rows have h2 title "Light Controls", so we identify them by which buttons are enabled
|
|
// Living Room Light (powered_on: false) - Turn On should be enabled, Turn Off disabled
|
|
// Bedroom Light (powered_on: true) - Turn Off should be enabled, Turn On disabled
|
|
let turnOnButton = null
|
|
let turnOffButton = null
|
|
|
|
for (const row of dashboardRows) {
|
|
// Get the fieldset in this row
|
|
const fieldsets = await row.findElements(By.css('fieldset'))
|
|
if (fieldsets.length === 0) continue
|
|
|
|
const buttons = await fieldsets[0].findElements(By.css('.action-button button'))
|
|
|
|
// Check each button to identify which entity this row represents
|
|
for (const btn of buttons) {
|
|
const title = await btn.getAttribute('title')
|
|
const disabled = await btn.getAttribute('disabled')
|
|
const isEnabled = disabled === null
|
|
|
|
if (title === 'Turn On Light' && isEnabled) {
|
|
// This is the Living Room Light row (Turn On is enabled because powered_on: false)
|
|
turnOnButton = btn
|
|
}
|
|
|
|
if (title === 'Turn Off Light' && isEnabled) {
|
|
// This is the Bedroom Light row (Turn Off is enabled because powered_on: true)
|
|
turnOffButton = btn
|
|
}
|
|
}
|
|
}
|
|
|
|
expect(turnOnButton).to.not.be.null
|
|
expect(turnOffButton).to.not.be.null
|
|
|
|
// Check that Turn On button is enabled (light is off)
|
|
const turnOnDisabled = await turnOnButton.getAttribute('disabled')
|
|
expect(turnOnDisabled).to.be.null
|
|
|
|
// Check that Turn Off button is enabled (light is on)
|
|
const turnOffDisabled = await turnOffButton.getAttribute('disabled')
|
|
expect(turnOffDisabled).to.be.null
|
|
})
|
|
|
|
it('Action without enabledExpression is always enabled', async function() {
|
|
await getRootAndWait()
|
|
|
|
// Navigate to actions view
|
|
await webdriver.get(runner.baseUrl())
|
|
|
|
// Wait for action buttons
|
|
await webdriver.wait(until.elementLocated(By.css('.action-button')), 10000)
|
|
|
|
// Find "Always Enabled Action" button
|
|
const actionButtons = await webdriver.findElements(By.css('.action-button button'))
|
|
let alwaysEnabledButton = null
|
|
|
|
for (const btn of actionButtons) {
|
|
const title = await btn.getAttribute('title')
|
|
if (title === 'Always Enabled Action') {
|
|
alwaysEnabledButton = btn
|
|
break
|
|
}
|
|
}
|
|
|
|
expect(alwaysEnabledButton).to.not.be.null
|
|
|
|
// Check that it's enabled
|
|
const disabled = await alwaysEnabledButton.getAttribute('disabled')
|
|
expect(disabled).to.be.null
|
|
})
|
|
})
|