ONAP Developer Set-Up
Follow the steps below to set up the development environment on your client machine, and to establish credentials with which you may access the repositories.
Create a Linux Foundation Account
Follow the instructions on the identity portal to create a Linux Foundation account and get access to the ONAP Gerrit instance.
Verify that you can log in at https://gerrit.onap.org/ and that you can see the ONAP list of repositories.
Basic Setup
Git
Install git for your OS in accordance with https://www.atlassian.com/git/tutorials/install-git
Since this is common for all OS, we will also use it to generate our SSH keys as well :
ssh-keygen
This should generate a private and public ssh key.
The public ssh key can then be uploaded to Gerrit (user setting, ssh keys, add new key) or elsewhere as needed for authorization.
Java
ONAP is moving to Java 11 but many projects still use Java 8.
Download and install the appropriate openjdk version in accordance with the component you are working and set JAVA_HOME environment variable to point to that
Maven
Download the latest Maven using installer from https://maven.apache.org/download.cgi
Add maven to your path variable.
To test the new installation run:
mvn -version
Use the settings.xml found in the oparent repo
Save this Maven settings.xml as your ~/.m2/settings.xml (windows c:\users\<username>\.m2)
WSL users can point to one common repo across Windows and Ubuntu as :
ln -s /mnt/c/Users/<username>/.m2 ~
Proxy settings for Maven (if required)
If you are behind a proxy you can add a proxy section to your settings.xml
OS Specific Instructions
MAC/OSX (in review under 10.15.7)
Redhat/CentOS (in review under RHEL 8.3)
Ubuntu (in review under 20.04 )
Connecting to ONAP Gerrit
SSH Connection (Recommended)
Log in to the Gerrit host https://gerrit.onap.org/, pull down the menu under your user name (at the extreme top right of the browser window), click on "Settings":
Click your account name on the top right corner of the website and click on Settings.
Add the public ssh key that you created in the previous step.
HTTPS Connection
Proxy setting for IntelliJ and Git (if required)
IDEs
Eclipse
Install Eclipse
Download and run the installer from: Install Eclipse. Select "Eclipse IDE for Java Developers" to install.
ONAP Eclipse Java Formatter
Download onap-java-formatter.xml and import into Eclipse.
(updates to the settings should be committed and merged back into the repository)
ONAP uses Google Java Style with some modifications. ( See Java code style )
Install useful plugins for Eclipse
Install EclEmma for code coverage and SonarLint for static code analysis.
Set up Sonar towards ONAP for Eclipse
To bind your projects to the ONAP Sonar server, follow the instructions below.
Your projects should be imported in to Eclipse before this.
To see messages from Sonar introduced by edits made in the projects, select "Window -> Show View -> Other...". Expand "SonarLint" and select "SonarLint -> On-The-Fly".
Setting up the ONAP Checkstyle for Eclipse
Set "ONAP" configuration in Eclipse
To set the newly built checkstyle files in Eclipse:
- Preferences->Checkstyle
- Click "New"
- Select "External Configuration File"
- Give it a name eg ONAP
- Point at the file <your_git_folder>/oparent/checkstyle/src/main/resources/onap-checkstyle/onap-java-style.xml
(assuming you have downloaded the oparent repo) - Click OK
- Select "ONAP" configuration and click "Set as Default"
- Select "Apply and Close"
Apply "ONAP" configuration to a project in Eclipse
Now we need to activate the checkstyle on one project and set it as the blueprint for all of them:
- Select a project in eclipse and right click->Properties→Checkstyle
- check "Checkstyle active for this project"
- Select the "ONAP" checkstyle profile
- Click "Apply and Close"
Spread blueprint to other projects for Eclipse
Now spread the profile to all other projects:
- Select all the projects you want to apply the profile to in the Eclipse project explorer (not the one that you set up above)
- Right click->Checkstyle->Configure projects from blueprint
- Select the project you set up above
- Now all the projects have the correct checkstyle setup.
Configure ONAP copyright for Eclipse
IntelliJ
Download & Install
see https://www.jetbrains.com/idea/download/#section=windows
Make sure you have added the Checkstyle plugin . Follow the below link
https://plugins.jetbrains.com/plugin/1065-checkstyle-idea
Configure ONAP code CheckStyle Plugin for IntelliJ
- Select, File, Settings, Tools, Checkstyle
- Click on + beside the 'Configuration File' box to add a configuration
- Set description to something like 'ONAP Rules'
- Click on Browse to select the file <your_git_folder>/oparent/checkstyle/src/main/resources/onap-checkstyle/onap-java-style.xml
(assuming you have downloaded the oparent repo) - Complete the Wizard (you can set exclusion properties if needed)
- Select the Configuration File you just added by selecting the relevant checkbox
- Click [OK] to close the settings popup
Configure ONAP code style auto formatting for IntelliJ (using the same checkstyle rules and automating it for you )
- Select, File, Settings, Editor, Code Style
- Click on the gear icon at the end of the line for "Scheme:"
- Optional: As importing a schema overrides the current scheme you might want to first use the 'Duplicate..' and 'Rename...' options to create an easily identifiable scheme e.g. 'ONAP Standard'
- Import Scheme→Checkstyle Configuration
- Click on Browse to select the file <your_git_folder>/oparent/checkstyle/src/main/resources/onap-checkstyle/onap-java-style.xml
(assuming you have downloaded the oparent repo) - Click OK
Configure ONAP copyright for IntelliJ
Set up SonarLint towards ONAP for IntelliJ
Prerequisites
- You need to be part of the onap organization in GitHub (see GitHub, click on your icon and select 'My Organizations')
If you are not a member of this organization email support.linuxfoundation.org and ask to be added to the onap organization in GitHub
Note. It is possible to enter a different organization if you at least member of 1 organization (you can create your own in GitHub).
The plugin wizard crashes if you are member of no organization at all, see this Bug: https://jira.sonarsource.com/browse/SLI-426 - Make sure you have added the SonarLint plugin
To use SonarLint with Onap projects you need to setup a connection with SonarCloud
- Select, File, Settings, Tools, SonarLint.
- Click on + beside the 'SonarCube / SonarClod connections' box to add a new connection
- Set Configuration Name to something like 'ONAP'
- Ensure sonarcloud is selected and click [Next]
- Click [Create Token]
- Select GitHub, logon and follow the GitHub wizard to create a Token
- Copy Token into IntelliJ wizard
- Click [Next] (might have to wait a little while your data is being downloaded)
- Select 'Open Network Automation Platform (ONAP)' from 'Your Organizations' and click [Next]
- Click [Finish] to close the wizard
- Click [OK] to leave settings
Then you need to bind each project to the corresponding project in GitHub/SonarCloud:
- Select, File, Settings, Tools, SonarLint, Project Settings
- Enable (check) 'Bind project to SonarQube / SonarCloud'
- Select the connection created above using the [Configure the connection] button
- Enter the project name (e.g. 'onap_ccsdk-sli-plugins') or select it using [Search in list..]
- Start typing the name of your project, and it should appear in a list box where it should be selected.
- Click [OK] to finish
Optional Tools & Utilities
Python
Check which version of python your project is using before installing.
Download Python from https://www.python.org/downloads/
Add python binary to Path.
Install "pip3", if you plan to use git-review.
|
---|
git-review (optional)
In a shell, type the following command (assumes you installed python above) :
pip3 install git-review
To use git review
, you have to be in a Git clone directory that already contains a (possibly hidden) .gitreview
configuration file (see Gerrit/Advanced usage#Setting up a repository for git-remote)
The Git and git-review installation steps above are derived from the description at: https://www.mediawiki.org/wiki/Gerrit/git-review#Windows
Configure Git to remember your Linux Foundation user name and email address (the user name and email address associated with your Linux Foundation login):
git config --global user.email <your_LF_account_email> git config --global --add gitreview.username <your_LF_user_name>
Configure git review
git config --global gitreview.remote origin
If you are using VPN, you might encounter a proxy problem while connecting to the Linux Foundation website. To avoid the problem, you should add the proxy setting in git config, using the following command:
git config --global https.proxy https://<proxy username>:<proxy password>@<proxy url> git config --global http.proxy http://<proxy username>:<proxy password>@<proxy url>
NOTE: When entering the proxy username, you might be required to add the domain name in front of the username.
Node-JS
The dcae build will install npm in most cases.
However you can install it yourself from https://nodejs.org/en/download/
Verify your installation by
npm -v
Local SonarQube Setup
It can be useful to have SonarQube running locally rather than pushing through CI for feedback.
This can be done using docker:
Images of the Community, Developer, and Enterprise Editions are available on Docker Hub.
Start the server by running:
$ docker run -d --name sonarqube -p 9000:9000 sonarqube:latest
- Log in to http://localhost:9000 with System Administrator credentials (login=admin, password=admin).
- Click the Create new project button to analyze your first project.
Other Optional Tools
The component you are working on may require additional tool installations, see the relevant section under Development Guides.
Troubleshooting & Know Issues
Windows Limitations
Some repos might not clone in Windows until some file paths are reduced below 255 chars.
Enable long paths in windows as
git config --system core.longpaths true
29 Comments
Chris Lott
If you have Git installed, you can use the "ssh-keygen" command from the Git Bash shell to generate a private-public key pair. (This is not as sophisticated as the Putty/plink configuration, but much easier to make it work.) Then look in your home directory for the .ssh/id_rsa.pub file and upload its contents to the Gerrit web site's SSH area. At that point you are set to type git commands in Git Bash.
HTH
Cheng (Ian) Liu
Exactly!
Michael Fay
Chris: good idea! If you've got editing permissions, go ahead and modify the page acccordingly.
Cang Chen
https://nexus.onap.org/content/repositories/public/ is also need for org.eclipse.core.runtime and sth else
xing xiaocheng
Is there any guide for remote debug with IDEs ? thx
Michael O'Brien
Xing,
Hi, good question and definitely required, I was planning on posting a section to the devops wiki on this later today. It involves exposing a different port for each docker container that has a JRE after an agreed on port like 5005 is enabled and the JVM restarted.
Ideally the compose files would enable the debug port in prep of this during deployment - I'll enter a JIRA on this as well.
UCA-25 - Getting issue details... STATUS
/michael
Steven Wright
In the web page above instructions for windows users there is mention of a known_hosts file. I was expecting to see a lists of known_hosts to be added somewhere here in the instructions.
"
Copy/paste the known_hosts entries listed, into a file named known_hosts under your .ssh profile (something like C:\Users\<my-id>\.ssh) (if known_hosts does not exist, create it).
Install NodeJS"
Michael O'Brien
Steven,
The mention of known_hosts can be ignored in my experience. The dynamic file will get created on your first ssh and fill up on every new connect with the server/key pair. Actually without a "-o StrictHostKeyChecking=no" in your ssh the known_hosts creates issues when you rebuild environments and swap out an IP for a local DNS name like robot - in that case you can also just remove that entry.
/michael
Mark Leonard
I disagree with the advice (in the Installing Git section) to checkout files with Windows-style line endings (on Windows). I am aware of some unit tests in ONAP that compare test-generated outputs with fixed expected outputs, stored as file resources within the git repo. Some of these unit tests directly compare the raw file contents and expect an exact match. Automatic CRLF conversion will cause test failures for such projects.
Keong Lim
Have experienced this in the AAI tests. The Java code could/should be changed to use the portable System.lineSeparator() method instead of literal "\n" and "\r\n" embedded strings.
Shreyaskumar Patel
I think we should use this configuration.
Chris Lott
Please add a pointer to the appropriate page that explains ONAP has adopted the Google no-tabs-just-spaces code style.
Mark Leonard
Here is the page that Chris refers to: Java code style
Tony Hansen
However, following that code style is not mandatory for R1 Amsterdam. Expect it to be mandatory in a future release.
Kornel Janiak
Does anybody recently proceeded successfully with clone of project on Windows e.g. 7?
Michael O'Brien
I find running VMware workstation on Windows and VMware Fusion on OSX works well - then you just develop in Ubuntu 16 or Redhat 7.3 in a VM.
When I was at Nokia we developed this way on our windows machines so we could be in sync with our Linux developer box - in a config way
That being said, I have ran into projects that came from a windows environment in ONAP (the CR/LF) so some developers here do run natively. I have cloned on a windows 10 machine but this is inside cygwin - will post details
Mayank Gupta
Hi All,
I was trying to build onap code and found some errors. can you please suggest is there any work around.
I am using git bash and OS is windows 10.
First time execution of command "repo init -u https://github.com/dbainbri-ciena/onap-manifest" found bellow error.
ImportError: No module named fcntl
i downloaded fcntl.py and paste it into python package library path.
after execution of same command there are some more errors for that i need help to resolve.please find bellow error:
$ repo init -u https://github.com/dbainbri-ciena/onap-manifest
Get https://gerrit.googlesource.com/git-repo/clone.bundle
Get https://gerrit.googlesource.com/git-repo
fatal: UriFormatException encountered.
actualUrl
$ Traceback (most recent call last):
File "C:\Users\mayangup\onap\.repo\repo/main.py", line 531, in <module>
_Main(sys.argv[1:])
File "C:\Users\mayangup\onap\.repo\repo/main.py", line 507, in _Main
result = repo._Run(argv) or 0
File "C:\Users\mayangup\onap\.repo\repo/main.py", line 180, in _Run
result = cmd.Execute(copts, cargs)
File "C:\Users\mayangup\onap\.repo\repo\subcmds\init.py", line 387, in Execute
git_require(MIN_GIT_VERSION, fail=True)
File "C:\Users\mayangup\onap\.repo\repo\git_command.py", line 121, in git_require
git_version = git.version_tuple()
File "C:\Users\mayangup\onap\.repo\repo\git_command.py", line 104, in version_tuple
ver_str = git.version()
File "C:\Users\mayangup\onap\.repo\repo\git_command.py", line 94, in version
if p.Wait() == 0:
File "C:\Users\mayangup\onap\.repo\repo\git_command.py", line 249, in Wait
rc = self._CaptureOutput()
File "C:\Users\mayangup\onap\.repo\repo\git_command.py", line 262, in _CaptureOutput
flags = fcntl.fcntl(s.fd, fcntl.F_GETFL)
AttributeError: 'module' object has no attribute 'F_GETFL'
Can you please suggest what will be the work around.
Thanks,
Mayank Gupta
ANT ANT
How do you download the ONAP JAR package? URL......
Peng Liu
Hi?
in Unix Setup > Ubuntu 16.04, it explains steps on Ubuntu 16.04. My question is that we can use Ubuntu1 16.04 version now ? Because in Deploying SDC on a Linux VM for Development , it highlights ubuntu 14.04 (do not use ubuntu 16.04).
which one is the latest tip?
Henrik Andersson
Hi!
I'm trying to push a commit towards gerrit.onap.org with the git review command, but get the following error:
$ git review -s
Problems encountered installing commit-msg hook
The following command failed with exit code 104
"GET https://gerrit.onap.org/tools/hooks/commit-msg"
Does anyone know what I have done wrong? I have tried following the instructions on this page. I'm working in Windows 10.
Thanks
Henrik Andersson
Keong Lim
Try following this instruction for installing the commit-msg hook:
https://gerrit.onap.org/r/Documentation/user-changeid.html#creation
In my case, instead of running "git review", I am running the equivalent "git push origin HEAD:refs/for/master" command (under Git Bash on Windows 7) which you can see here: https://gerrit.onap.org/r/Documentation/user-upload.html#push_create
Keong
Henrik Andersson
Thank you! This helped me along!
/Henrik
Michael O'Brien
I was ok on windows 10 using python 2.7, pip and git review - this has helped with other issues on linux/osx
f you get a 404 on commit hooks - reconfigure - https://lists.onap.org/pipermail/onap-discuss/2018-May/009737.html
curl -kLo `git rev-parse --git-dir`/hooks/commit-msg http:
//gerrit.onap.org/r/tools/hooks/commit-msg; chmod +x `git rev-parse --git-dir`/hooks/commit-msg
git commit --amend
git review -R
Dan Timoney
I'm trying to set up the IntelliJ Gerrit plugin. I set the URL to https://gerrit.onap.org , user name to my Linux Foundation id, and password to my HTTP password from Gerrit. When I click "Test", I'm getting an 404 error saying it can't find /a/accounts/self.
Has anyone else had this issue? I tried adding my LF id to the URL (https://djtimoney@gerrit.onap.org), and tried using my usual Gerrit password and neither works.
Sandeep Shah
Hi Dan - Please try http://gerrit.onap.org/r...It should work
Dan Timoney
Thanks! That was my problem. I had a feeling it was pilot error on my part
Stanislav Chlebec
settings.xml file
..
create an ~/.m2 folder and copy our settings.xml there
settings.xml -> https://jira.onap.org/secure/attachment/10829/settings.xml
...
...
The most current settings.xml that you should use to build ONAP can be found in the oparent repo at https://git.onap.org/oparent/plain/settings.xml
https://git.onap.org/oparent/plain/settings.xml -> https://git.onap.org/oparent/plain/settings.xml
...
These two text directs to two different files.
It should be united.
Liam Fallon
Update: The latest release of OpenJdk 8 (version 1.8.0_191) fixes this issue. Make sure to pull the latest software updates in Ubuntu to get that update.
There's a bug in the latest OpenJDK 8 Java, which cases all JUnit test cases to fail. I have observed it on a machine running Ubuntu 18.04 on openjdk-8-jre:amd64 8u181-b13-1ubuntu0.18.04.1See the following Stack Overflow article:https://stackoverflow.com/questions/53010200/maven-surefire-could-not-find-forkedbooter-clasand the first answer on the same article.The workaround that worked for me was to downgrade the compiler version to openjdk-8-jdk=8u162-b12-1Remove all openjdk packagessudo apt remove --purge openjdk-8-jdk openjdk-8-jdk-headless openjdk-8-jre openjdk-8-jre-headless
Now install the previous version of OpenJDKNow your unit tests should run again.Amir Mohamad
Ubuntu 16.04 TLS bare-metal, trying to deploy SDC locally
I've ran into problems mainly because of Docker, installed using this script [1] as in this page Setting Up Your Development Environment [2]:
I've posted this here for reference and to help whoever reproduces the same errors.
[1] https://releases.rancher.com/install-docker/17.03.sh
[2] https://wiki.onap.org/display/DW/Setting+Up+Your+Development+Environment