You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
197 lines
6.4 KiB
197 lines
6.4 KiB
'use strict'
|
|
const init = require('../helpers/init')
|
|
const sauce = require('./sauce')
|
|
|
|
module.exports = {
|
|
|
|
before: function (browser, done) {
|
|
init(browser, done)
|
|
},
|
|
|
|
'Should zoom in editor': function (browser) {
|
|
browser.waitForElementVisible('div[data-id="mainPanelPluginsContainer"]')
|
|
.openFile('browser/1_Storage.sol')
|
|
.waitForElementVisible('*[data-id="editorInput"]')
|
|
.checkElementStyle('*[data-id="editorInput"]', 'font-size', '12px')
|
|
.click('*[data-id="tabProxyZoomIn"]')
|
|
.click('*[data-id="tabProxyZoomIn"]')
|
|
.checkElementStyle('*[data-id="editorInput"]', 'font-size', '14px')
|
|
},
|
|
|
|
'Should zoom out editor': function (browser) {
|
|
browser.waitForElementVisible('*[data-id="editorInput"]')
|
|
.checkElementStyle('*[data-id="editorInput"]', 'font-size', '14px')
|
|
.click('*[data-id="tabProxyZoomOut"]')
|
|
.click('*[data-id="tabProxyZoomOut"]')
|
|
.checkElementStyle('*[data-id="editorInput"]', 'font-size', '12px')
|
|
},
|
|
|
|
'Should display compile error in editor': function (browser) {
|
|
browser.waitForElementVisible('*[data-id="editorInput"]')
|
|
.waitForElementVisible('*[class="ace_content"]')
|
|
.click('*[class="ace_content"]')
|
|
.sendKeys('*[class="ace_text-input"]', 'error')
|
|
.pause(2000)
|
|
.waitForElementVisible('.ace_error')
|
|
},
|
|
|
|
'Should minimize and maximize codeblock in editor': function (browser) {
|
|
browser.waitForElementVisible('*[data-id="editorInput"]')
|
|
.waitForElementVisible('.ace_open')
|
|
.click('.ace_start:nth-of-type(1)')
|
|
.waitForElementVisible('.ace_closed')
|
|
.click('.ace_start:nth-of-type(1)')
|
|
.waitForElementVisible('.ace_open')
|
|
},
|
|
|
|
'Should add breakpoint to editor': function (browser) {
|
|
browser.waitForElementVisible('*[data-id="editorInput"]')
|
|
.waitForElementNotPresent('.ace_breakpoint')
|
|
.click('.ace_gutter-cell:nth-of-type(1)')
|
|
.waitForElementVisible('.ace_breakpoint')
|
|
},
|
|
|
|
'Should load syntax highlighter for ace light theme': function (browser) {
|
|
browser.waitForElementVisible('*[data-id="editorInput"]')
|
|
.checkElementStyle('.ace_keyword', 'color', aceThemes.light.keyword)
|
|
.checkElementStyle('.ace_comment.ace_doc', 'color', aceThemes.light.comment)
|
|
.checkElementStyle('.ace_function', 'color', aceThemes.light.function)
|
|
.checkElementStyle('.ace_variable', 'color', aceThemes.light.variable)
|
|
},
|
|
|
|
'Should load syntax highlighter for ace dark theme': function (browser) {
|
|
browser.waitForElementVisible('*[data-id="verticalIconsKindsettings"]')
|
|
.click('*[data-id="verticalIconsKindsettings"]')
|
|
.waitForElementVisible('*[data-id="settingsTabThemeDark"]')
|
|
.click('*[data-id="settingsTabThemeDark"]')
|
|
.pause(2000)
|
|
.waitForElementVisible('*[data-id="editorInput"]')
|
|
.checkElementStyle('.ace_keyword', 'color', aceThemes.dark.keyword)
|
|
.checkElementStyle('.ace_comment.ace_doc', 'color', aceThemes.dark.comment)
|
|
.checkElementStyle('.ace_function', 'color', aceThemes.dark.function)
|
|
.checkElementStyle('.ace_variable', 'color', aceThemes.dark.variable)
|
|
},
|
|
|
|
'Should highlight source code': function (browser) {
|
|
browser.addFile('sourcehighlight.js', sourcehighlightScript)
|
|
.openFile('browser/sourcehighlight.js')
|
|
.executeScript('remix.exeCurrent()')
|
|
.editorScroll('down', 60)
|
|
.waitForElementPresent('.highlightLine32')
|
|
.checkElementStyle('.highlightLine32', 'background-color', 'rgb(8, 108, 181)')
|
|
.waitForElementPresent('.highlightLine40')
|
|
.checkElementStyle('.highlightLine40', 'background-color', 'rgb(8, 108, 181)')
|
|
.waitForElementPresent('.highlightLine50')
|
|
.checkElementStyle('.highlightLine50', 'background-color', 'rgb(8, 108, 181)')
|
|
},
|
|
|
|
'Should remove 1 highlight from source code': function (browser) {
|
|
browser.addFile('removeSourcehighlightScript.js', removeSourcehighlightScript)
|
|
.openFile('browser/removeSourcehighlightScript.js')
|
|
.executeScript('remix.exeCurrent()')
|
|
.openFile('browser/3_Ballot.sol')
|
|
.editorScroll('down', 60)
|
|
.waitForElementNotPresent('.highlightLine32')
|
|
.checkElementStyle('.highlightLine40', 'background-color', 'rgb(8, 108, 181)')
|
|
.checkElementStyle('.highlightLine50', 'background-color', 'rgb(8, 108, 181)')
|
|
},
|
|
|
|
'Should remove all highlights from source code': function (browser) {
|
|
browser.addFile('removeAllSourcehighlightScript.js', removeAllSourcehighlightScript)
|
|
.openFile('browser/removeAllSourcehighlightScript.js')
|
|
.executeScript('remix.exeCurrent()')
|
|
.openFile('browser/3_Ballot.sol')
|
|
.editorScroll('down', 60)
|
|
.waitForElementNotPresent('.highlightLine32')
|
|
.waitForElementNotPresent('.highlightLine40')
|
|
.waitForElementNotPresent('.highlightLine50')
|
|
.end()
|
|
},
|
|
|
|
tearDown: sauce
|
|
}
|
|
|
|
var aceThemes = {
|
|
light: {
|
|
keyword: 'rgb(147, 15, 128)',
|
|
comment: 'rgb(35, 110, 36)',
|
|
function: 'rgb(0, 0, 162)',
|
|
variable: 'rgb(253, 151, 31)'
|
|
},
|
|
dark: {
|
|
keyword: 'rgb(0, 105, 143)',
|
|
comment: 'rgb(85, 85, 85)',
|
|
function: 'rgb(0, 174, 239)',
|
|
variable: 'rgb(153, 119, 68)'
|
|
}
|
|
}
|
|
|
|
const sourcehighlightScript = {
|
|
content: `
|
|
(async () => {
|
|
try {
|
|
const pos = {
|
|
start: {
|
|
line: 32,
|
|
column: 3
|
|
},
|
|
end: {
|
|
line: 32,
|
|
column: 20
|
|
}
|
|
}
|
|
await remix.call('editor', 'highlight', pos, 'browser/3_Ballot.sol')
|
|
|
|
const pos2 = {
|
|
start: {
|
|
line: 40,
|
|
column: 3
|
|
},
|
|
end: {
|
|
line: 40,
|
|
column: 20
|
|
}
|
|
}
|
|
await remix.call('editor', 'highlight', pos2, 'browser/3_Ballot.sol')
|
|
|
|
const pos3 = {
|
|
start: {
|
|
line: 50,
|
|
column: 3
|
|
},
|
|
end: {
|
|
line: 50,
|
|
column: 20
|
|
}
|
|
}
|
|
await remix.call('editor', 'highlight', pos3, 'browser/3_Ballot.sol')
|
|
} catch (e) {
|
|
console.log(e.message)
|
|
}
|
|
})()
|
|
`
|
|
}
|
|
|
|
const removeSourcehighlightScript = {
|
|
content: `
|
|
(async () => {
|
|
try {
|
|
await remix.call('editor', 'discardHighlightAt', 32, 'browser/3_Ballot.sol')
|
|
} catch (e) {
|
|
console.log(e.message)
|
|
}
|
|
})()
|
|
`
|
|
}
|
|
|
|
const removeAllSourcehighlightScript = {
|
|
content: `
|
|
(async () => {
|
|
try {
|
|
await remix.call('editor', 'discardHighlight')
|
|
} catch (e) {
|
|
console.log(e.message)
|
|
}
|
|
})()
|
|
`
|
|
}
|
|
|