Releases: gemini-testing/gemini
0.4.1
0.4.0
-
Crop region for screenshots is calculated via client script inside
browser instead ofgemini. This allows to issue fewer requests to
Selenium Server speeding up total tests run time. This feature breaks
compatibility with old browsers (IE< 9). -
New config format, which allows to specify full set of capabilities
for browsers:browsers: phantomjs: phantomjs opera12: browserName: opera version: '12.06' platform: 'WINDOWS' firefox28: browserName: firefox version: '28.0' firefox27: browserName: firefox version: '27.0'
-
Correctly capture screenshots of regions out of initial browser
viewport in browsers, that can't capture full page (Operaand
Chromeat the time of writing). -
outline-widthof an elements is now also taken into account when
calculating crop region. -
Add
debugoptions to config file. If set totrue,geminiwill
print debug logs to STDOUT. (@arikon). -
Add
httpsection to config file which allows to configure HTTP
timeout (http.timeout) retry count (http.retries) and delay
between retries (http.retryDelay). (@arikon). -
Asynchronous errors stacktraces in browser actions (such as not found
element) will point to users code. -
More HTTP requests to Selenium will run in parallel speeding up
gather/testcommands (@arikon). -
If
geminiis run without subcommand, help text will be shown.
0.3.4
0.3.3
- Allow to use multiple reporters in
testcommand. - Throw error when creating multiple suites of the same name within
the same parent. - Throw error when creating multiple states of the same name within
the suite. - Throw error when creating suite that will be unable to run (
has states and hasn't url or capture region); - Check argument types of
SuiteBuildermethods. - Check argument types of all actions methods.
- Shorter stacktraces for invalid elements errors.
- Correctly handle offsets in
mouseMoveactions. - Fix error when
gridUrlwas required even if there is only
phantomjsbrowser.
0.3.2
0.3.1
-
Ability to set additional capabilities for all browsers, using
capabilitiesoption in.gemini.yml:capabilities: option1: value, option2: value
-
Non-existent directories, passed to
gatherandtestcommands will
be filtered out -
If fatal error occurs,
geminiwill always exit with 1 status code -
If test fails or state error occurs,
geminiwill always exit with 2
status code. -
When
geminiis unable to launch browser, more clearer error message
will be displayed.
0.3.0
-
Elements to take screen shots of and elements to perform action
on are now defined differently.setElementsandsetDynmaicElements
methods removed.New way to define elements for screenshot:
suite.setCaptureElements('.selector1', '.selector2', ...)
Or using array:
suite.setCaptureElements(['.selector1', '.selector2', ...])
To get element to perform action on, you can now pass
selectors directly to the actions:suite.capture('state', function(actions, find) { actions.click('.button'); });
To avoid multiple lookups for the same element you can use
findfunction which is now passed to the state callback:suite.capture('state', function(actions, find) { var button = find('.button'); actions.mouseMove(button); .click(button); });
-
Add
suite.before(function(action, find))which can be used to
perform some actions before the first state. Context is shared
between before hook and all of suite's state callbacks.You can use
beforeto look for element only once for the state:suite.before(function(actions, find) { this.button = find('.buttons'); }) .capture('hovered', function(actions, find) { actions.mouseMove(this.button); }) .capture('pressed', function(actions, find) { actions.mouseDown(this.button); });
Or to perform some actions before first state without taking
screenshot:suite.before(function(actions, find) { actions.click('.button'); });
-
Add
suite.skip()method which allows to skip suite in some set of
browsers:suite.skip()- skip in all browsers.suite.skip('chrome')- skip in all versions of Chrome.suite.skip({name: 'chrome', version: '33.0'})- skip in Chrome 33.0suite.skip(['chrome', 'opera'])- skip in Chrome and Opera
-
Public API now has constants for special keys to use in
sendKeysactions
(i.e.gemini.CONTROLforCTRLkey).
0.2.1
0.2.0
-
New test suites API. Plans are replaced by test suites defined by explicit call.
Old version:
module.exports = function(plan) { plan.setName('some name') .setElements(...) .setDynamicElements(...) .capture(...) };
New API:
var gemini = require('gemini'); gemini.suite('some name', function(suite) { suite.setElements(...) .setDynamicElements(...) .capture(...) };
Suites also can be nested. In this case, child suite inherits all properties
from the parent.gemin.suite('parent', function(suite) { gemini.suite('child', function(child) { gemini.suite('grandchild', function(grandchild) { }); }); });
-
.reload()method is removed. Use nested suite if you need to reload browser. -
Added action to run any JS code in browser context:
actions.executeJS(function(window) { window.alert('Hello!'); });
-
sendKeysaction can optionally take an receive an element to send keys to.actions.sendKeys(elements.someInput, 'hello');
-
Added ability to specify browser version in
.gemini.ymlbrowsers: - {name: 'pahantomjs', version: '1.9'}
-
Tree reporter is now used for
gathercommand.
0.1.1
phantomjsalways starts maximized. This fixes the error, when some shadows didn't fit in crop rectangle.- Action on dynamic element that does not currently exists causes non-fatal error. Such error will fail only one state, the rest will continue running.
gathercommand now reports browser name.- browsers are always closed, even if there was an error.