JLineup has many configuration options. A JLineup cycle with it’s before and after steps is called job throughout this documentation. Job configuration settings can be separated between two scopes, global and site. Some of the options can be used in global as well as in site scope for convenience.
Site specific settings always have precedence over global settings with the same name.
A JLineup job config is a JSON document. Additionally to JSON standard, JLineup can work with line or multiline comments in it’s config. // comment
or /* comment */
are ok. Also ok are trailing commas.
For JLineup CLI, the default name of the config file is lineup.json.
It’s searched in the current working directory. A different path can be specified with the
--config
option.
If using the web server variant, you have to POST the config via REST API.
A basic configuration with default settings can look like this:
{
"urls": {
"https://www.otto.de": {
}
}
}
This config leads JLineup to https://www.otto.de. All other settings like window size, timeouts etc. stay default.
What about those global and site settings?
{
"urls": {
"https://www.otto.de": {
"->": "SITE SETTINGS GO HERE"
}
},
"->": "GLOBAL SETTINGS GO HERE"
}
This basic example shows the concept of global and url settings:
{
"urls": {
"http://www.otto.de": {
"paths": [
"/"
],
"devices" : [{
"width" : 800,
"height" : 600
}],
"max-scroll-height":50000
},
"https://www.example.com": {
"paths": [
"/",
"somepath"
],
"devices" : [{
"width" : 800,
"height" : 600
},{
"width" : 1000,
"height" : 800
}],
"max-scroll-height":10000
}
},
"browser": "chrome",
"wait-after-page-load": 1
}
As you can see, paths, window-widths and max-scroll-height are configured on url level, the browser and the wait-after-page-load options are global for all sites in this job.
This is a full configuration with example values:
{
"urls": {
"https://www.example.com": {
"setup-paths": ["/internal/do/some/setup"],
"cleanup-paths": ["/internal/do/some/cleanup"],
"paths": [
"/",
"someOtherPath"
],
"max-diff": 0.0,
"cookies": [
{
"name": "exampleCookieName",
"value": "exampleValue",
"domain": "https://www.example.com",
"path": "/",
"expiry": "1970-01-01T01:00:01+0100",
"secure": true
}
],
"env-mapping": {
"live": "www"
},
"local-storage": {
"exampleLocalStorageKey": "value"
},
"session-storage": {
"exampleSessionStorageKey": "value"
},
"devices" : [ {
"width" : 800,
"height" : 600
}, {
"width" : 1000,
"height" : 800
}, {
"width" : 1200,
"height" : 1000
} ],
"max-scroll-height": 100000,
"wait-after-page-load": 0.0,
"wait-after-scroll": 0.0,
"wait-for-no-animation-after-scroll": 0.0,
"warmup-browser-cache-time": 0.0,
"wait-for-fonts-time": 0.0,
"javascript": "console.log(\u0027This is JavaScript!\u0027)",
"hide-images": false,
"http-check": {
"enabled": false
},
"ignore-anti-aliasing": false,
"strict-color-comparison": false,
"wait-for-selectors": [
".wait-for-class"
],
"wait-for-selectors-timeout": 20.0,
"fail-if-selectors-not-found": false,
"remove-selectors": [
"#remove-id"
]
}
},
"browser": "Chrome",
"wait-after-page-load": 0.0,
"page-load-timeout": 120,
"report-format": 2,
"screenshot-retries": 0,
"threads": 0,
"timeout": 600,
"debug": false,
"log-to-file": false,
"check-for-errors-in-log": true,
"http-check": {
"enabled": false
}
}
What are all those options about? Here are all the details.
browser
Defines, which browser is used for the JLineup job. The chosen browser has to be installed on the used system.
JLineup downloads a webdriver, but it doesn’t install a real browser during runtime!
Chrome
, Firefox
, Chrome-Headless
, Firefox-Headless
"Chrome-Headless"
"browser": "Chrome-Headless"
urls
JLineup job settings for one or multiple sites have to be configured as JSON subdocument here
"urls": {
"https://www.otto.de": {}
}
paths
These paths are appended to the current site url and screenshotted individually
[ "" ]
"paths": [ "/", "someOtherPath" ]
window-widths
Every path in the site config will be screenshotted in these given window-widths of the browser
Since JLineup 4.0.0, there is a newer devices option which replaces window-widths, see devices
[ 800 ]
"window-widths": [
600,
800,
1000
]
max-diff
This is the maximum accepted difference of a single screenshot of the current site. If the difference is greater than the configured maximum, then the failing url + path + window-width combination AND the complete JLineup job are marked as erroneous.
The difference of every single screenshot at every scrolling position is calculated as a percentage between 0% (0.0) and 100% (1.0) which means that every pixel of the two compared images is different.
Advice: This option should be handled with care. I strongly suggest a value of 0.0 (which is default) because every accepted pixel difference could be any unintended change - which should be looked at by a human being! A CI job can’t decide what change is intended or not through simply accept a percentage of pixel differences.
0.0
0.0
1.0
"max-diff": 0.01
cookies
A list of cookies that are set on the site. A cookie document can simply consist of name
and value
.
Alternatively, you can specify a full cookie with name
, value
, domain
, path
, expiry
and secure
.
See the example for details. The expiration time has to be written as ISO8601 string.
{}
alternating-cookies
This feature is helpful if you wish to test different sets of cookies for a site.
A list of lists of cookies that are set on the site. A cookie document can simply consist of name
and value
.
Alternatively, you can specify a full cookie with name
, value
, domain
, path
, expiry
and secure
.
See the cookies
example for details. The expiration time has to be written as ISO8601 string.
If you want to see the different cookies in the HTML report, you can specify show-in-report
for them.
{}
local-storage
Sets key value pairs to the local storage of the site
"local-storage": {
"exampleLocalStorageKey": "exampleLocalStorageValue"
}
session-storage
Sets key value pairs to the session storage of the site
max-scroll-height
When using Chrome or Firefox, JLineup scrolls the page like a normal browser user, because that’s the way the web works today. Nearly no page fits the screen, and modern pages tend to grow to huge sizes. To not scroll endlessly on large pages, there is a maximum value.
50000
"max-scroll-height": 100000
wait-after-page-load
On modern web pages with JavaScript and asynchronous loading mechanisms, it’s hard to tell when a page is really loaded completely. JLineup uses Selenium under the hood. Selenium’s get() method blocks until the browser/page fires an onload event (files and images referenced in the html have been loaded, but there might be JS calls that load more stuff dynamically afterwards). This option waits for the specified amount of time after this onload event was fired. This value should be chosen carefully by observing the time your screenshotted page needs until it’s complete.
If your reports show half loaded pages, you should increase the value until this does not happen any more. If you set it too high, you waste time in your runs.
0
"wait-after-page-load": 3.5
wait-after-scroll
If your reports show half loaded artifacts in lower parts of the page, you should increase this value until this does not happen any more. If you set it too high, you increase the time for site scrolling drastically. As long as your page does not load content dynamically during scrolling, you can keep this very low or at default.
0
"wait-after-scroll": 1.1
warmup-browser-cache-time
If this value is greater than 0, JLineup simply loads the page prior to the screenshot run and waits the specified amount of seconds to fill the browser cache with everything that can be cached during page load. It can be helpful to have a prewarmed cache while doing the first screenshots of a site in a run.
0
"warmup-browser-cache-time": 5
javascript
This is a mighty option. You can specify and run any given JavaScript after loading the page and prior to making the screenshots. This can be used for various things, like throwing things out of the DOM by id or class, replacing images etc. Be creative but careful :D
Since JLineup 4.2.0, the JavaScript can be enriched with a special function:
jlineup.sleep(int milliseconds)
You can mix this into your JavaScript to have real execution pauses, without having to write additional
async/await or setTimeout functions. This only works in simple, procedural JavaScript blocks, for example in click sequences.
Don’t use it inside of function definitions, only in top level code.
null
"javascript": "console.log('This is JavaScript!')"
http-check
It may be required to check connectivity to a page by checking a http return code before making screenshots of it. Real browsers don’t report a return code to Selenium, because Selenium looks at a page from a user perspective. JLineup can make this extra check for any desired http return codes.
This can be helpful, if you want to fail a JLineup job if the page shows a 404. If the before and after run are done on a non-reachable page without a HTTP check, the job would return no error - both error pages are visually identical.
If enabled
is set to true, all return codes that are not in the whitelist of allowed codes are regarded as failure.
If you don’t explicitly specify allowed codes in the http-check document, there is a default list of these accepted
HTTP return codes: 200,202,204,205,206,301,302,303,304,307,308
Additionally, you can setup error-signals
, which accepts a list of strings. If one of those strings appears in the
body of the checked page, the job also returns an error. This is helpful, if your page returns one of the allowed codes,
but isn’t in the desired state (It was introduced to check for a “sorry”-page that did return a HTTP 200).
{ "enabled": false, "allowed-codes": [ 200,202,204,205,206,301,302,303,304,307,308 ], "error-signals":[] }
env-mapping
This is a convenience option that can replace parts of the domain that are specified in the config before making screenshots.
This can be nice if you want to replace environments that are generated into your lineup.json that don’t match the real site url. One Example: At OTTO, the generated live step would result in a generated url like https://live.otto.de, which is in reality reachable under https://www.otto.de.
{}
hide-images
This option can be used to hide all images on the page before making screenshots. This can be useful, if you only want to check the layout, but not the possibly changing content of pictures on a site.
false
"hide-images": true
wait-for-selectors
Instead of waiting for a fixed time until your page may be loaded, you can specify certain CSS selectors that should
be in the DOM until JLineup starts to make screenshots. The wait-for-page-load
will happen afterwards.
null
"wait-for-selectors": [ ".wait-for-class", "#wait-for-id" ]
Since: 4.1.0
wait-for-selectors-timeout
If you use wait-for-selectors
to check if your page is loaded, this is the time that will be waited for until all
selectors have been found. If the selector(s) didn’t appear in time, it depends on fail-if-selectors-not-found
if
JLineup will throw an error or goes on with screenshots regardless of the missing DOM objects.
"wait-for-selectors-timeout": 20.0
Since: 4.1.0
fail-if-selectors-not-found
See wait-for-selectors-timeout
above.
"fail-if-selectors-not-found": true
Since: 4.1.0
remove-selectors
You can specify a set of CSS selectors that will be used to remove all nodes found by these selectors from the DOM. This is useful if you have content on your site that you don’t want in your screenshot comparison. Real life cases are animated things, third party content you can’t control or content that changes on every call.
The remove operation happens after wait-for-page-load
and wait-for-selectors
are finished.
Note: Advanced replacements of dom objects can be realized using the javascript
feature.
null
"remove-selectors": [ "#remove-id", ".remove-class" ]
Since: 4.1.0
wait-for-fonts-time
If your web fonts load too slow, there may be cases that your page is rendered without a default alternate font, which is replaced by the loaded font during a screenshot run. You can explicitly wait for font loading with this option.
This should be rarely needed.
"wait-for-fonts-time": 3
ignore-anti-aliasing
Browsers use anti-aliasing to render smooth fonts, rounded edges, svgs etc. Sometimes, the rendering is not deterministic between to renderings of an identical web page. JLineup can ignore differences that are caused by anti-aliased pixels. Use this, if JLineup detects differences at edges, that can’t be spotted by human eyes in the before and after screenshots.
false
"ignore-anti-aliasing": true
Since: 4.0.0
strict-color-comparison
By default, JLineup compares screenshots in a non-strict mode that takes into account that some slight color differences look same for the human eye. To check this, the CIEDE2000 metric is used. See https://en.wikipedia.org/wiki/Color_difference for details.
If you don’t want this, you can enable the strict color comparison which checks for exactly identical RGB values.
false
"strict-color-comparison": true
Since: 4.0.0
devices
In older versions, you just could define a global window height and several window widths for your JLineup run.
To be backwards compatible, this still works, but you should prefer the newer devices
option.
Device config allows you to use custom pixel-ratio and mobile emulation in Chrome, and it brings custom user agents.
The device name “DESKTOP” is generic and leads to the default behavior which works in all browsers: You can specify window width and height and the user agent of the used browser is used.
If you want mobile emulation in Chrome, just specify “MOBILE” as device name. Chrome will be in mobile emulation mode for this config. You can also use the device names that Chrome shows in Dev Tools when doing mobile emulation manually, like “iPhone X”. See https://chromedriver.chromium.org/mobile-emulation for more details on this feature.
Other browsers ignore this feature and just use window size and user agent.
"devices":[
{
"device-name": "DESKTOP",
"width": 800,
"height": 800
}
]
Examples:
` “devices”:[ { “device-name”: “iPhone X” } ] `
` “devices”:[ { “device-name”: “MOBILE”, “width”: 600, “height”: 1200, “pixel-ratio”: 2.0, “user-agent”: “My special mobile” },{ “device-name”: “DESKTOP”, “width”: 600, “height”: 1200, “user-agent”: “My special user agent string” “touch”: true } ] `
Since: 4.0.0
setup-paths
These paths are called before doing the JLineup screenshot run. You can use this to setup test data at your target service. The cookies that are used for the screenshots are also used for these calls.
null
"setup-paths": [ "/some/setup/path", "/some/other/setup/path" ]
Since: 4.2.0
cleanup-paths
These paths are called after doing the JLineup screenshot run. You can use this to cleanup test data at your target service. The cookies that are used for the screenshots are also used for these calls.
null
"cleanup-paths": [ "/some/cleanup/path", "/some/other/cleanup/path" ]
Since: 4.2.0
page-load-timeout
This value is passed through to Selenium for loading the pages. From the Selenium docs:
Sets the amount of time to wait for a page load to complete before throwing an error.
If the timeout is negative, page loads can be indefinite.
This timeout can help to not wait indefinitely when there are connectivity or page loading problems.
120
"page-load-timeout": 180
name
You can define a name for your specific JLineup job. The name is shown in the report and on the jobs overview page if you use the web version of JLineup.
null
"name": "Cool name for my JLineup Job"
window-height
This is the height of the browser window which JLineup uses.
Since JLineup 4.0.0, there is a newer devices option which replaces window-widths, see devices
800
"window-height": 1000
report-format
This is a deprecated option to switch to an older JSON report format, which is not that useful. Shouldn’t be used any more and will be removed in the future.
1
or 2
2
"report-format": 2
screenshot-retries
This option should be used with care. Better don’t use it at all. It may help in a flaky environment, but it’s better to fix the flakiness then to use this option.
JLineup makes screenshots for every permutation of url
+ path
+ window-width
+ alternating-cookies
. Internally, this combination is
called a screenshot context. If you specify retries and there is any error during screenshotting one of those
contexts, this context is retried until a maximum of specified retries is reached.
0
"screenshot-retries": 2
threads
If you specify multiple urls, paths or window widths in your config, JLineup can run multiple browser instances in parallel to speed up the job. Keep in mind, that memory and CPU requirements increase when multiple browsers are opened at the same time.
If you use the CLI version, this simply sets the number of threads. Although the default is 0
, JLineup uses at least
one thread, so 0
or 1
make no difference in that case.
The 0
has another meaning for the web server version, because a maximum of allowed threads per job is configured in
the web server properties. If the job config says 0
(which is default), the job uses the maximum of allowed
threads. You can override this through setting an explicit value. If your job configuration value is
greater than the maximum in the web server properties, the latter wins - so your job cannot use more threads than the
server allows. Simply leave this configuration at default until you have special requirements for this particular job.
0
"threads": 2
timeout
This is a global and hard timeout for the whole JLineup job. If the job isn’t finished after this time, it fails. This can help to end stalled jobs. Of course, a job shouldn’t stall, but there may be rare cases (which should be fixed!) - this timeout can help to not have an indefinite wait for JLineup in your pipeline in those cases.
600
"timeout": 300
debug
This option is for CLI only. If you set this to true, JLineup logs on DEBUG
level. Can be useful for the CLI version, if you track down strange
behavior or bugs - or if you simply want to know which steps JLineup is doing in detail.
false
"debug": true
log-to-file
This option is for CLI only. The job output is logged to the file jlineup.log
in the current working directory if
specified.
false
"log-to-file": true
check-for-errors-in-log
This option only works for Chrome/Chromium. If there is any error logged to the Chrome console and this setting is
set to true
, an error is raised for this screenshot and the run fails.
false
"check-for-errors-in-log": false