Cora-eclipse is a project to enable easy setup of an Eclipse install for Cora development, using Eclipse and Docker.
I am running this on linux so, change as needed for other platforms.
- Make sure you have git and docker set up on your local machine
- Make a directory where you want everything installed /x/y/z/cora (/mnt/depot/cora)
- cd to your new directory
- Clone this repository:
git clone https://github.com/olovm/cora-eclipse.git
The runAll script will take you through the entire process of setting up a docker based development environment for Cora. It will go through all needed steps.
You can get your docker group id by running;
getent group docker
Run:
./cora-eclipse/runAll.sh dockerGroupId
or run:
./cora-eclipse/runAll.sh dockerGroupId master nocache
This option will do a pull of the base image, and not use the cache so that you get the latest version of the packages that gets installed from Fedora.
This scrip will, run the following headers automatically
Automatically run by runAll
this will take some time as it downloads quite a few things, eclipse, tomcat, etc
Automatically run by runAll
- workspace (for your eclipse workspace)
- eclipse (for your eclipse installation)
- eclipseP2 (for files shared between multiple installations of eclipse)
- m2 (for maven files)
Automatically run by runAll
When the container starts for the first time will it run the installation part of entrypoint.sh. This will
clone all Cora repositories, add other remotes to all of them, install needed npm karma in cora-jsclient and
start the eclipse installer (oomph).
There are a few things that needs to be choosen in the installer:
-
You need to use the advanced mode
-
Browse for setup files for eclipse, /home/yourUserName/workspace/cora-eclipse/oomph/EclipseForCora.setup (use the plussign to add)
-
Java 11+ VM, set it to: /usr/lib/jvm/java-11-openjdk
next step
- In next step browse for setup for projects, /home/yourUserName/workspace/cora-eclipse/oomph/CoraProjects.setup (use the plussign to add)
- Make sure "Cora projects" are marked
next step
- Choose installation location: "Installed in the specified absolute folder location"
- Fill in path for "Root install folder": set it to /home/yourUserName/eclipse
- Fill in path for "Installation location": set it to /home/yourUserName/eclipse
- Choose Workspace location rule: "Located in the absolute folder location"
- Fill in path for "Workspace location": /home/yourUserName/workspace
- Fill in path for "JRE 15 Location": /usr/lib/jvm/java-16-openjdk
next step
finnish
saros might not allow you to log in, if so, skipp that step and do it later
This should get you through the installer and will eventually start eclipse and do a first run to setup eclipse.
You can click on the spinning arrows, in the bottom of the screen to see what the setup does.
Once the setuptask are finnished, no more spinning arrows, close eclipse, and then close the installer window.
You are now ready to do a first startup of the environment.
Start the environment by running:
./eclipseForCora/startEclipseForCora.sh
Do the following in the listed order to avoid problems!
- Go in under preferences and make sure the latest java is choosen as default jre
- In project explorer, under the three little dots, deselect working sets
- Mark all projects and refresh them, menu or F5 (this will make sure eclipse sees files in target folders)
- Start and stop the servers (in server tab) in the following order:
- Tomcat v9.0 systemOne
- Tomcat v9.0 alvin
- Tomcat v9.0 diva
- Go under External Tools Configurations (play icon with toolbox) and run linkJsClientToTomcats
- Go under External Tools Configurations (play icon with toolbox) and run copyMetadata
- Go under External Tools Configurations (play icon with toolbox) and start the docker containers for development by running systemoneStartDevDockers
- Start fitnesse, Go under Run Configurations (play icon) and start fitnesse
- Start the tomcat servers for systemOne
- See links section below to find the running system
(or similar for Alvin or DiVA)
After starting the appropriate servers and containers from inside eclipse, the following will be exposed:
SystemOne web:http://localhost:38080/jsclient/theClient.html
Fitnesse:http://localhost:38090/fitnesse/FrontPage
SystemOne REST:http://localhost:38080/systemone/rest/
Solr:http://localhost:38983/solr/
Karma:http://localhost:39876/
Alvin web:http://localhost:38081/jsclient/theClient.html
Fitnesse:http://localhost:38091/fitnesse/FrontPage
Alvin REST:http://localhost:38081/alvin/rest/
Solr:http://localhost:38984/solr/
Fedora Commons:http://localhost:38088/fedora/
DiVA web:http://localhost:38082/jsclient/theClient.html
Fitnesse:http://localhost:38092/fitnesse/FrontPage
DiVA REST:http://localhost:38082/diva/rest/
Solr:http://localhost:38985/solr/
Fedora Commons:http://localhost:38089/fedora/
prefrences / security / secure storage / contents
remove git from default secure storage
as described here:
username: your normal username password: your token
- Set your username in .gitconfig found in the root catalog where you installed the system, do this
from the host system as there currently seems to be some issue with setting information in the
file from the docker side of things.
[user]
name = yourusername
email = user@organisation.org - Go under External Tools Configurations (play icon with toolbox), run fetchAllFromLSU
- Go under External Tools Configurations (play icon with toolbox), run mergeProjectsFromLSUMaster (confirm in console)
- Go under External Tools Configurations (play icon with toolbox), run mvnPomCleanInstallAllButDocker
- Go under External Tools Configurations (play icon with toolbox), run mvnPomCleanInstallDevDocker
- Rightclick any project, and choose, maven / update project... (or F5) select all projects and run
- Stop and start containers and tomcat servers.
- cd to your eclipse install directory cd /x/y/z/cora/cora-eclipse
- do a git pull: git pull
- list remote branches: git ls-remote
- checkout latest branch: git checkout 201903_2
- cd up to cora directory: cd ..
- run: ./cora-eclipse/runAll.sh 1001 201903_2
- continue with installation
For alvin server go into the launch configuration / arguments under VM arguments add
-Djavax.net.ssl.trustStore="/home/olov/workspace/cora-docker-fedora/files/fedoraKeystore.jks" -Djavax.net.ssl.trustStorePassword="changeit"
- Go under External Tools Configurations (play icon with toolbox) and run checkOutLatestTagOfAllProjects
- Go under External Tools Configurations (play icon with toolbox) and run mvnPomCleanInstallAllButDocker
- Go under External Tools Configurations (play icon with toolbox) and run checkOutMasterOfAllProjects
https://stackoverflow.com/questions/47582157/eclipse-marketplace-plug-ins-silent-install Given a Marketplace install URL (https://marketplace.eclipse.org/marketplace-client-intro?mpc_install={ID}), construct the API URL as https://marketplace.eclipse.org/node/{ID}/api/p. Retrieve the XML file from that URL and look for the repository URL in the updateURL tag, and the available features in the ius tag. You'll need to append .feature.group to each IU feature listed
connect to shell in devEnvironment:
docker exec -it eclipse202103forcora3 bash
to export data from running DiVA db run: pg_dump -U diva -h diva-cora-docker-postgresql -p 5432 -t organisation diva > ~/workspace/diva-cora-docker-postgresql/docker/data/exported.sql
Add the following to the top of the page, then use remoteDebugging such as DivaFitnesseDebug to connect to it when testing.
!path {java.class.path}
!define COMMAND_PATTERN {/usr/lib/jvm/java-16-openjdk/bin/java -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 -cp %p %m}