Skip to content

Latest commit

 

History

History
237 lines (182 loc) · 12.7 KB

INSTALL.md

File metadata and controls

237 lines (182 loc) · 12.7 KB

Setup Instructions

You may build and run the demo either manually or by using Docker or Nix.

The purpose of this demo is to serve as a template project for starting to develop with DiffDetective, as well as to give examples on how to use and integrate DiffDetective in your projects. We hence recommend the manual setup because it enables you to use DiffDetective in any of your own Maven projects.

The Nix and Docker setups build the demo to a runnable jar file. We also provide scripts for running the Demo using Nix dependencies and inside Docker but we do not recommend the complete Docker setup because the demo launches a graphical user interface which frequently causes problems when inside of Docker (see Troubleshooting section at the bottom of this file). We hence recommend (1) to build either manually or with Nix or with Docker and (2) to run the produced jar file manually. (Windows users should not use the Nix setup except if they are experts on WSL2, XServers, and Nix (see REQUIREMENTS.md).)

Once you decided for a setup (Manual/Docker/Nix), check the requirements needed for the respective setup in the REQUIREMENTS.md file.

In case you encounter problems during the setup, you may have a look at the Troubleshooting section at the bottom of this file.

Manual Build

Follow the setup instructions on the DiffDetective website for building and installing DiffDetective with Maven (and not with Nix). These instructions make you clone the repo and install it. Afterward, come back here and you should be ready to go.

To run the demo, you can do so via an IDE or terminal. In our screencast, we show how to build and run the Demo in IntelliJ. Alternatively, here we show how to build and run the demo on the command line.

Open a terminal and navigate to the top level of this repository. You can then build the demo running the following Maven command:

mvn package

Afterward, the jar files can be found in the target directory as the build output. To run the demo, invoke java on the jar file that includes any dependencies:

java -jar target/diffdetectivedemo-1.0.0-jar-with-dependencies.jar

The expected output and behavior of the jar file is explained below in the section Expected Output. Make sure that you are at the top level of this repository in the terminal (i.e, the directory containing this INSTALL.md file).

Automatic Build

We provide two methods for automatically building this demo:

Starting the docker deamon

If you want to use Docker to build the jar for you, Docker needs to be installed and running. Check the requirements needed for the Docker setup in the REQUIREMENTS.md file. You may also need to start the Docker daemon before any Docker commands can be run.

  • On Linux: Typically, the docker deamon runs automatically, so there is nothing to do. Otherwise, run sudo systemctl start docker.
  • On Windows: Open the search bar using the 'Windows Key' and search for 'Docker' or 'Docker Desktop'.

More detailed instructions on starting the deamon are given here on the docker website.

Docker Build on Windows

Open a terminal (preferably Windows PowerShell) and navigate to the repository's directory (the directory containing this INSTALL.md). Then, create the docker image

docker build -t diffdetective-demo .

You can verify that the image was created successfully by running

docker images

and checking that an image called diffdetective-demo is listed.

To extract the built jar you can run

docker run --volume "${pwd}:/output:rw" diffdetective-demo:1.0.0 /bin/cp /DiffDetective/share/java/DiffDetective-Demo.jar /output

and execute it using

java -jar DiffDetective-Demo.jar

Experimental: Alternatively, You can run the image and thus the demo with the following command:

docker run --net=host -e DISPLAY=host.docker.internal:0 --volume="$PWD/data/output:/home/user/data/output:rw" -t diffdetective-demo

You may get some font errors, which you can ignore (see Troubleshooting below). The parameters --net=host and -e DISPLAY=host.docker.internal:0 are required to launch graphical user interfaces from within Docker.

Nix or Docker Build on Linux

You can use the build-jar.sh script to build the Demo jar using Nix or Docker. The build-jar.sh script will automatically choose the build method depending on the available software (Nix or Docker, in that order). You might require elevated privileges to execute Docker commands (e.g., sudo ./build-jar.sh or adding the user to the docker or wheel group). See Docker's post-installation steps for more information. Also, it is best to install required software (e.g., Nix, Docker) using your distro's package manager if it is available.

Clone and navigate to this repository (the directory containing this INSTALL.md). Then, simply build the jar using the provided script:

./build-jar.sh

The jar can then be executed with

java -jar DiffDetective-Demo.jar

Complete Docker Setup on Linux

Experimental: You can build and start a demo Docker container with

./docker.sh build
./docker.sh demo

Nix Build

Nix can be used to reproducibly build this DiffDetective demo. To use Nix, you need to have Nix installed on your system. See REQUIREMENTS.md for instructions on how to install Nix.

Notice for Windows users: You must run the following commands from within a WSL2 terminal. Also, make sure to clone this repository to a directory within WSL and not to a Windows directory. Otherwise, the Nix setup might fail due to incompatibilities with the file system.

Notice for Nix flake users: If you have flakes enabled, you can just use nix run github:VariantSync/DiffDetective-Demo to run the demo instead of the following instructions.

Clone and navigate to this repository in a terminal. Then simply build the Demo with

nix-build

Afterwards, the produced jar file is located at result/share/java/DiffDetective-Demo.jar. You can run it manually with Java (requires Java 17 or higher):

java -jar result/share/java/DiffDetective-Demo.jar

or alternatively with the provided wrapper script:

./result/bin/DiffDetective-Demo

Expected Output

The expected output is close to the output shown at the end of the screencast. When you run the demo, a text-based diff should be printed to the terminal, followed by four windows opening up: Screenshot of expected output. After closing these windows (use ESC key for fast closing), there should be another four windows opening with the same trees and diffs but not in the simplified "foo/bar" version. After closing these windows, a small example analysis of the xterm repository should run in the terminal. The analysis should take about 30s-5min, and its output to terminal should look similar to this:

2024-04-27 11:40:46 INFO    [AnalysisRunner.run] Reading and cloning git repositories from/to: data\repos
2024-04-27 11:40:46 INFO    [AnalysisRunner.run] Writing output to: data\output
2024-04-27 11:40:46 INFO    [AnalysisRunner.run] Loading datasets file: data\demo-dataset.md
2024-04-27 11:40:46 INFO    [AnalysisRunner.run] Performing validation on the following repositories:
2024-04-27 11:40:46 INFO    [AnalysisRunner.run]   - xterm from https://github.com/DiffDetective/xterm.git
2024-04-27 11:40:46 INFO    [AnalysisRunner.run] Preloading repositories:
2024-04-27 11:40:46 INFO    [Repository.load] Loading git at data\repos\xterm ...
2024-04-27 11:40:47 INFO    [Analysis.forEachRepository]  === Begin Processing xterm ===
2024-04-27 11:40:47 INFO    [Analysis.forEachCommit] >>> Scheduling asynchronous analysis on 8 threads.
2024-04-27 11:40:47 INFO    [Analysis.forEachCommit] <<< done in 0.222s
2024-04-27 11:40:47 INFO    [Analysis.forEachCommit] >>> Run Analysis
2024-04-27 11:41:21 INFO    [DemoAnalysis.endBatch] Batch done: 11 commits analyzed
2024-04-27 11:41:38 INFO    [DemoAnalysis.endBatch] Batch done: 20 commits analyzed
2024-04-27 11:41:39 INFO    [DemoAnalysis.endBatch] Batch done: 20 commits analyzed
2024-04-27 11:41:39 INFO    [DemoAnalysis.endBatch] Batch done: 20 commits analyzed
2024-04-27 11:41:40 INFO    [DemoAnalysis.endBatch] Batch done: 20 commits analyzed
2024-04-27 11:41:40 INFO    [DemoAnalysis.endBatch] Batch done: 20 commits analyzed
2024-04-27 11:41:40 INFO    [Analysis.forEachCommit] <<< done in 53.09s
2024-04-27 11:41:40 INFO    [Analysis.exportMetadataToFile] Metadata:
    analysis: my analysis
    repository: xterm
    big diffs: 188
    runtime with multithreading in seconds: 53.09
    total commits: 111

2024-04-27 11:41:40 INFO    [Analysis.forEachRepository]  === End Processing xterm after 53.379s ===
2024-04-27 11:41:40 INFO    [AnalysisRunner.run] Done

The output files of the analysis should be located at data/output.

Troubleshooting

ERROR [VariationDiffApp.layoutNodes] java.io.IOException: Cannot run program "dot": error=2, No such file or directory

You may choose to ignore this error. This happens when dot is not installed on your system. dot is shipped with graphviz. To fix, please install graphviz (see REQUIREMENTS.md). The demo can run without graphviz though (but then all graph nodes in the GUI are located at the same point).

Expected Output: There is only a single node in the shown graphs / All nodes are at the same location.

When graphviz is not installed, DiffDetective cannot compute a layout for the graph nodes in the GUI. To fix, please install graphviz (see REQUIREMENTS.md).

Error during nix-build on Windows (11)

When you encounter the following error:

Running phase: buildPhase
/nix/store/kv5wkk7xgc8paw9azshzlmxraffqcg0i-stdenv-linux/setup: line 114: $'\r': command not found
/nix/store/kv5wkk7xgc8paw9azshzlmxraffqcg0i-stdenv-linux/setup: line 131: pop_var_context: head of shell_variables not a function context
error: builder for '/nix/store/y5qjl7ly9zmmkyp6gi2cpzszn84q8a3a-DiffDetective-Demo-1.0.0-maven-deps.drv' failed with exit code 127
error: 1 dependencies of derivation '/nix/store/3hyzjh1jfjaac2vgi5zj7mhw5cvr0gym-DiffDetective-Demo-1.0.0.drv' failed to build

you probably downloaded the demo to a Windows directory but tried to use the Nix setup from WSL2. Please clone the demo to a directory within WSL2. For Windows users though, we recommend to use Docker instead of Nix.

Docker says my image was built 54 years ago.

That is in purpose. Timestamps are not reproducible, so we fixed the timestamp to the UNIX timestamp 1.

Fontconfig error: Cannot load default config file: No such file: (null)

This is a warning that you may ignore. It means that some fonts requested by the GUI could not be found on your system. As long as you see text in your GUI, this is fine.

error: a 'x86_64-linux' with features {kvm} is required to build '/nix/store/sw5bbvy20jy61r6jh39l6qxvn9jv1mx0-docker-layer-DiffDetective-Demo.drv', but I am a 'x86_64-linux' with features {benchmark, big-parallel, nixos-test, uid-range}

This error is raised by Nix when there is no hardware support for virtualization. In this case, our build script falls back to Docker. It is likely that this fall back failed, which typically happens when Docker could not be started. To fix, start the docker daemon as it was probably not running.

Gtk-Message: 00:08:30.171: Failed to load module "colorreload-gtk-module"

This error can be savely ignore. The colorreload-gtk-module is used for theming and, hence, is not useful in this scenario.

error: experimental Nix feature 'nix-command' is disabled; add '--extra-experimental-features nix-command' to enable it

You ran Nix flakes without having enabled it. Either enable it by adding the extra parameters to the call as indicated in the error message, or stick to the non-experimental nix commands as described above (recommended).

Exception in thread "main" java.nio.file.NoSuchFileException: data/examples/simple_v1.txt

The demo could not find one of this input files. This likely happened because you ran the demo from a working directory that is not the top level of this repository in the terminal (i.e, the directory containing this INSTALL.md file). To fix, navigate to the root directory of this repository in your terminal and run the demo again.