JLineup can be run as a small web service which offers a simple REST interface to take JLineup jobs. JLineup WEB requires at least Java 17.
You can simply download the web version by getting the jlineup-web.jar from Maven Central in a terminal window:
wget https://repo1.maven.org/maven2/de/otto/jlineup-web/4.13.0/jlineup-web-4.13.0.jar -O jlineup-web.jar
Now you have a jlineup-web.jar
in your current directory.
For best results, you need a “real” web browser installed on your system. JLineup supports Google Chrome (Chromium also works) or Firefox at the moment. As JLineup is written in Java, you need a Java Runtime Environment in version 11 or higher. OpenJDK is fine.
If those prerequisites are fulfilled, you can start the JLineup server:
java -jar jlineup-web.jar
If you see an error similar to this:
[main] ERROR o.a.catalina.core.StandardService - Failed to start connector [Connector[HTTP/1.1-8080]]
...
Caused by: java.net.BindException: Address already in use
something else is running on port 8080 on your machine. You could stop the conflicting server or you could run JLineup on another port like this:
java -Dserver.port=5000 -jar jlineup-web.jar
Everything is up and running now for your first steps. The examples assume that JLineup runs on port 8080. Change them if you run it on a different one.
Head to http://localhost:8080/internal/status with a browser to see JLineup’s status page. It should look similar to this:
JLineup has a small set of methods, which live in one context:
/runs
/runs/{runId}
/runs
202 Accepted
return code./runs/{runId}
Hint: You can always see a human readable representation of your jobs on http://localhost:8080/internal/reports
Use a REST client of your choice ans post the example config to your server:
POST http://localhost/runs/
Body:
{
"name": "Example",
"urls": {
"https://www.example.com" : {}
},
"browser": "chrome-headless"
}
Content-Type: application/json
You should get an 202 as answer. Then just post the same config again to create a second run.
If you go to http://localhost:8080/internal/reports now, you should see your two runs like this:
Both runs finished the ‘before’ step, like their status says.
Now start the ‘after’ run for one of them by taking the existing ID and post to it:
POST http://localhost/runs/PUT_THE_ID_HERE
.
The reports page should show that one of the runs went through the ‘after’ step and a report was generated:
You can click on the Report button to see the report:
Click on the green url to open the details:
The JLineup web server uses Edison Microservice which is based on Spring Boot. You can configure it by application.properties or yaml like any Spring Boot application.
These are the internal defaults:
jlineup:
working-directory: /tmp/jlineup/
screenshots-directory: report-{id}
report-directory: report-{id}
max-parallel-jobs: 1
cleanupProfile: true
edison:
application:
title: JLineup
description: Takes screenshots of webpages and checks for differences
spring:
application:
name: JLineup
You can save this file as application.yml and put it into the same directory as jlineup-web.jar. After that, you can change it’s contents to your needs.
Additional to the JLineup configuration properties below, you can use all Spring Boot Application Properties to specify application behavior, as JLineup is a Spring Boot 2 app.
Also, there are Edison Microservice Application Properties that can be used to configure the core and populate the status page of JLineup.
jlineup.working-directory
This is the path to JLineup’s working directory during jobs. JLineup needs write permissions to this folder’s path. It will be created during first run if not existing.
/tmp/jlineup/
jlineup.screenshots-directory
This folder will contain the screenshots of the JLineup job. If you don’t
want to overwrite previous job’s screenshots, you can use {id}
as
placeholder for the job id that is randomly created when you start a new
job. So you’ll have unique folders for all job screenshots.
By default screenshots and report will go to the same folder, which is totally fine.
The path is relative to the working directory!
report-{id}
jlineup.max-parallel-jobs
JLineup can run multiple jobs concurrently. Make sure there is enough
RAM on the machine for max-parallel-jobs
x max-threads-per-job
browser instances that can result from these settings.
See jlineup.max-threads-per-job also.
1
jlineup.max-threads-per-job
JLineup can run multiple threads to speed up jobs. See threads configuration in job to see how these settings go together.
This specifies, how many browser instances per job JLineup maximally starts on this JLineup server instance.
Make sure there is enough RAM on the machine for
max-parallel-jobs
x max-threads-per-job
browser instances that can result from these settings.
See jlineup.max-parallel-jobs also.
4
jlineup.installed-browsers
JLineup web will deny requests for jobs that contain a browser that is not in the list of installed browsers. If you want to allow only a subset of installed browsers or if you don’t have Firefox and Chrome installed, you can narrow the settings.
chrome-headless, firefox-headless
jlineup.chrome-launch-parameters
You can specify any Chrome command line parameters,
that you want to handle to the Chrome instances launched by JLineup.
You can use {id}
as placeholder in parameters. This will be replaced
with the job id at Chrome launch time. This is useful if you want isolated
profiles for every job, just specify something like this: --user-data-dir=/tmp/jlineup-chrome-profile-{id}
See here for a list of Chrome command line switches
--use-shm=false, --bwsi
jlineup.firefox-launch-parameters
You can specify any Firefox command line parameters,
that you want to handle to the Firefox instances launched by JLineup.
You can use {id}
as placeholder in parameters. This will be replaced
with the job id at Firefox launch time.
See here for a list of Firefox command line options.
-private
jlineup.cleanupProfile
If you specify a profile directory for Chrome or Firefox, JLineup will delete it after the job is finished. If you want to keep the profile, set this to false.
A Chrome custom profile directory is specified by --user-data-dir=/path/to/profile
.
A Firefox custom profile directory is specified by -profile /path/to/profile
.
Use {id}
as placeholder in the path to get a unique profile for every job.
false
true