mirror of
https://github.com/OliveTin/OliveTin
synced 2026-05-03 20:50:39 +00:00
78 lines
3.1 KiB
JavaScript
78 lines
3.1 KiB
JavaScript
import { describe, it, before, after, afterEach } from 'mocha'
|
|
import { expect } from 'chai'
|
|
import { By } from 'selenium-webdriver'
|
|
import {
|
|
getRootAndWait,
|
|
takeScreenshotOnFailure,
|
|
} from '../../lib/elements.js'
|
|
|
|
describe('config: cssClass', function () {
|
|
before(async function () {
|
|
await runner.start('cssClass')
|
|
})
|
|
|
|
after(async () => {
|
|
await runner.stop()
|
|
})
|
|
|
|
afterEach(function () {
|
|
takeScreenshotOnFailure(this.currentTest, webdriver)
|
|
})
|
|
|
|
it('cssClass is applied to action button (link component)', async function () {
|
|
await getRootAndWait()
|
|
|
|
const buttonWithClass = await webdriver.findElements(By.css('.action-button button.test-custom-class'))
|
|
expect(buttonWithClass).to.have.length.at.least(1, 'Action button should have cssClass test-custom-class on the button')
|
|
|
|
const classAttr = await buttonWithClass[0].getAttribute('class')
|
|
expect(classAttr).to.include('test-custom-class')
|
|
})
|
|
|
|
it('custom theme applies background color to action button via cssClass', async function () {
|
|
await getRootAndWait()
|
|
|
|
const buttonWithClass = await webdriver.findElements(By.css('.action-button button.test-custom-class'))
|
|
expect(buttonWithClass).to.have.length.at.least(1, 'Action button with test-custom-class should exist')
|
|
|
|
const bgColor = await buttonWithClass[0].getCssValue('background-color')
|
|
expect(bgColor, 'Theme theme.css should set .action-button button.test-custom-class background to rgb(32, 64, 128)')
|
|
.to.match(/rgba?\(\s*32\s*,\s*64\s*,\s*128\s*(,\s*1)?\s*\)/)
|
|
})
|
|
|
|
it('cssClass override: style rule targeting custom class wins over component styles', async function () {
|
|
await getRootAndWait()
|
|
|
|
const buttonWithClass = await webdriver.findElements(By.css('.action-button button.test-custom-class'))
|
|
expect(buttonWithClass).to.have.length.at.least(1)
|
|
|
|
const beforePx = await buttonWithClass[0].getCssValue('border-top-width')
|
|
await webdriver.executeScript(`
|
|
var style = document.getElementById('cssclass-test-override-style');
|
|
if (!style) {
|
|
style = document.createElement('style');
|
|
style.id = 'cssclass-test-override-style';
|
|
style.textContent = '.test-custom-class { border-top-width: 31px !important; }';
|
|
document.head.appendChild(style);
|
|
} else {
|
|
style.textContent = '.test-custom-class { border-top-width: 31px !important; }';
|
|
}
|
|
`)
|
|
await webdriver.sleep(150)
|
|
|
|
const afterPx = await buttonWithClass[0].getCssValue('border-top-width')
|
|
const afterNum = parseInt(afterPx, 10)
|
|
expect(afterNum).to.be.greaterThan(10, 'Override targeting cssClass should win over component 1px (before=' + beforePx + ' after=' + afterPx + ') (#804)')
|
|
})
|
|
|
|
it('cssClass is applied to display component', async function () {
|
|
await getRootAndWait()
|
|
|
|
const displayElements = await webdriver.findElements(By.css('.display.test-display-class'))
|
|
expect(displayElements).to.have.length.at.least(1, 'Display component with cssClass test-display-class should be in DOM')
|
|
|
|
const classAttr = await displayElements[0].getAttribute('class')
|
|
expect(classAttr).to.include('test-display-class')
|
|
})
|
|
})
|