Lusheng Ji | 72c4fba | 2017-10-10 18:12:22 +0000 | [diff] [blame] | 1 | .. This work is licensed under a Creative Commons Attribution 4.0 International License. |
| 2 | .. http://creativecommons.org/licenses/by/4.0 |
VENKATESH KUMAR | 7f3e453 | 2020-11-18 16:30:36 -0500 | [diff] [blame^] | 3 | .. _build: |
Lusheng Ji | 72c4fba | 2017-10-10 18:12:22 +0000 | [diff] [blame] | 4 | |
Lusheng Ji | eaac78d | 2018-06-06 00:20:03 -0400 | [diff] [blame] | 5 | Building DCAE |
| 6 | ============= |
Lusheng Ji | 72c4fba | 2017-10-10 18:12:22 +0000 | [diff] [blame] | 7 | |
Lusheng Ji | 72c4fba | 2017-10-10 18:12:22 +0000 | [diff] [blame] | 8 | |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 9 | Description |
| 10 | ----------- |
| 11 | DCAE has multiple code repos and these repos are in several different languages. All DCAE projects are built in similar fashion, following Maven framework as Maven projects. Although many DCAE projects are not written in Java, adopting the Maven framework does help including DCAE projects in the overall ONAP building methodology and CICD process. |
| 12 | |
Lusheng Ji | eaac78d | 2018-06-06 00:20:03 -0400 | [diff] [blame] | 13 | All DCAE projects use ONAP **oparent** project POM as ancestor. That is, DCAE projects inherent all parameters defined in the oparent project which include many ONAP wide configuration parameters such as the location of various artifact repos. |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 14 | |
| 15 | A number of DCAE projects are not written Java. For these projects we use the CodeHaus Maven Execution plugin for triggering a Bash script at various stages of Maven lifecycle. The script is mvn-phase-script.sh, located at the root of each non-Java DACE project. It is in this script that the actual build operation is performed at different Maven phases. For example, for a Python project, Maven test will actually trigger a call to tox to conduct project unit tests. |
| 16 | |
VENKATESH KUMAR | e21c848 | 2020-11-12 15:00:02 -0500 | [diff] [blame] | 17 | Below is a list of the repositories and their sub-modules, and the language they are written in. |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 18 | |
| 19 | * dcaegen2 |
| 20 | |
| 21 | - docs (rst) |
| 22 | - platformdoc (mkdoc) |
| 23 | |
| 24 | * dcaegen2.analytics |
| 25 | |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 26 | |
Vijay VK | 2648c6d | 2018-09-19 04:30:37 +0100 | [diff] [blame] | 27 | * dcaegen2.analytics.tca-gen2 |
VENKATESH KUMAR | e21c848 | 2020-11-12 15:00:02 -0500 | [diff] [blame] | 28 | |
Vijay VK | 2648c6d | 2018-09-19 04:30:37 +0100 | [diff] [blame] | 29 | - dcae-analytics (Java) |
| 30 | - eelf-logger (Java) |
| 31 | |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 32 | * dcaegen2.collectors |
| 33 | |
Lusheng Ji | eaac78d | 2018-06-06 00:20:03 -0400 | [diff] [blame] | 34 | - dcaegen2.collectors.snmptrap (Python) |
| 35 | - dcaegen2.collectors.ves (Java) |
Vijay VK | 2648c6d | 2018-09-19 04:30:37 +0100 | [diff] [blame] | 36 | - dcaegen2.collectors.hv-ves (Kotlin) |
| 37 | - dcaegen2.collectors.datafile (Java) |
Vijay VK | 6b0fa46 | 2019-05-20 16:06:11 +0100 | [diff] [blame] | 38 | - dcaegen2.collectors.restconf (Java) |
Vijay VK | 2648c6d | 2018-09-19 04:30:37 +0100 | [diff] [blame] | 39 | |
| 40 | * dcaegen2.services |
| 41 | |
| 42 | - dcaegen2.services.heartbeat (Python) |
| 43 | - dcaegen2.services.prh (Java) |
Vijay VK | 6b0fa46 | 2019-05-20 16:06:11 +0100 | [diff] [blame] | 44 | - dcaegen2.services.bbs-eventprocessor (Java) |
| 45 | - dcaegen2.services.pm-mapper (Java) |
| 46 | - dcaegen2.services.ves-mapper (Java) |
| 47 | - dcaegen2.services.son-handler (Java) |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 48 | |
| 49 | * dcaegen2.deployments |
| 50 | |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 51 | - scripts (bash, python) |
Vijay VK | 2648c6d | 2018-09-19 04:30:37 +0100 | [diff] [blame] | 52 | - tls-init-container (bash) |
| 53 | - k8s-bootstrap-container (bash) |
| 54 | - healthcheck-container (Node.js) |
| 55 | - k8s-bootstrap-container (bash) |
Vijay VK | 6b0fa46 | 2019-05-20 16:06:11 +0100 | [diff] [blame] | 56 | - tca-cdap-container (bash) |
| 57 | - multisite-init-container (python) |
| 58 | - dcae-remote-site (helm chart) |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 59 | |
| 60 | * dcaegen2.platform |
| 61 | |
| 62 | * dcaegen2.platform.blueprints |
| 63 | |
| 64 | - blueprints (yaml) |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 65 | - input-templates (yaml) |
| 66 | |
Lusheng Ji | eaac78d | 2018-06-06 00:20:03 -0400 | [diff] [blame] | 67 | * dcaegen2.platform.cli (Python) |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 68 | |
| 69 | - component-json-schemas (yaml) |
| 70 | - dcae-cli (Python) |
| 71 | |
| 72 | * dcaegen2.platform.configbinding (Python) |
| 73 | |
VENKATESH KUMAR | be32a31 | 2019-06-07 01:31:10 -0400 | [diff] [blame] | 74 | * dcaegen2.platform.deployment-handler (NodeJS) |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 75 | |
VENKATESH KUMAR | be32a31 | 2019-06-07 01:31:10 -0400 | [diff] [blame] | 76 | * dcaegen2.platform.inventory-api (Java) |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 77 | |
| 78 | * dcaegen2.platform.plugins |
| 79 | |
| 80 | - cdap (Python) |
| 81 | - dcae-policy (Python) |
| 82 | - docker (Python) |
| 83 | - relationships (Python) |
Vijay VK | 6b0fa46 | 2019-05-20 16:06:11 +0100 | [diff] [blame] | 84 | - k8splugin (Python) |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 85 | |
| 86 | * dcaegen2.platform.policy-handler (Python) |
| 87 | |
VENKATESH KUMAR | be32a31 | 2019-06-07 01:31:10 -0400 | [diff] [blame] | 88 | * dcaegen2.platform.servicechange-handler (Clojure) |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 89 | |
| 90 | * dcaegen2.utils |
| 91 | |
| 92 | - onap-dcae-cbs-docker-client (Python) |
| 93 | - onap-dcae-dcaepolicy-lib (Python) |
| 94 | - python-discovery-client (Python) |
| 95 | - python-dockering (Python) |
| 96 | - scripts (bash) |
| 97 | |
Lusheng Ji | 72c4fba | 2017-10-10 18:12:22 +0000 | [diff] [blame] | 98 | |
Lusheng Ji | 72c4fba | 2017-10-10 18:12:22 +0000 | [diff] [blame] | 99 | Environment |
| 100 | ----------- |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 101 | Building is conducted in a Linux environment that has the basic building tools such as JDK 8, Maven 3, Python 2.7 and 3.6, docker engine, etc. |
Lusheng Ji | 72c4fba | 2017-10-10 18:12:22 +0000 | [diff] [blame] | 102 | |
| 103 | |
| 104 | Steps |
| 105 | ----- |
Lusheng Ji | a73548f | 2017-11-05 19:24:05 -0500 | [diff] [blame] | 106 | Because of the uniform adoption of Maven framework, each project can be built by running the standard Maven build commands: mvn clean, install, deploy, etc. For projects with submodules, the pom file in the project root will descent to the submodules and complete the submodule building. |
| 107 | |
| 108 | |
| 109 | Artifacts |
| 110 | --------- |
| 111 | Building of DCAE projects produce three different kinds of artifacts: Java jar files, raw file artifacts (including yaml files, scripts, wagon packages, etc), Pypi packages, and docker container images. |
| 112 | |
| 113 | |
| 114 | |