diff --git a/.cz.toml b/.cz.toml index 92846d7..2f09d4f 100644 --- a/.cz.toml +++ b/.cz.toml @@ -1,5 +1,5 @@ [tool] [tool.commitizen] name = "cz_conventional_commits" -version = "0.0.1" +version = "0.0.4" tag_format = "v$version" diff --git a/.github/workflows/android-dep.yml b/.github/workflows/android-dep.yml new file mode 100644 index 0000000..c3c45eb --- /dev/null +++ b/.github/workflows/android-dep.yml @@ -0,0 +1,49 @@ + ############################################################################# + # Copyright (c) 2022 Cisco and/or its affiliates. + # Licensed under the Apache License, Version 2.0 (the "License"); + # you may not use this file except in compliance with the License. + # You may obtain a copy of the License at: + # + # http://www.apache.org/licenses/LICENSE-2.0 + # + # Unless required by applicable law or agreed to in writing, software + # distributed under the License is distributed on an "AS IS" BASIS, + # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + # See the License for the specific language governing permissions and + # limitations under the License. + ############################################################################## + +name: Docker Android Dep + +on: + schedule: + - cron: '0 3 * * *' + push: + branches: + - main + +jobs: + build: + name: 'Build' + runs-on: ubuntu-latest + steps: + - name: "Build:checkout" + uses: actions/checkout@v3 + with: + fetch-depth: 0 + - name: 'Get Previous tag' + id: previoustag + uses: "WyriHaximus/github-action-get-previous-tag@v1" + with: + fallback: v0.0.0 + + - name: Publish to Registry + uses: elgohr/Publish-Docker-Github-Action@v4 + with: + name: ${{github.repository}}/android-dep + password: ${{ secrets.GITHUB_TOKEN }} + username: ${{ github.actor }} + registry: ghcr.io + dockerfile: android/ci/Dockerfile_dep + buildargs: BASE_IMAGE=ghcr.io/${{github.repository}}/android-env:latest + tags: latest,${{ steps.previoustag.outputs.tag }} \ No newline at end of file diff --git a/.github/workflows/android-env.yml b/.github/workflows/android-env.yml index 900d7d7..8988ce7 100644 --- a/.github/workflows/android-env.yml +++ b/.github/workflows/android-env.yml @@ -17,7 +17,7 @@ name: Docker Android Environment on: schedule: - - cron: '0 0 1 */6 *' + - cron: '0 0 1 */1 *' push: branches: - main @@ -28,10 +28,20 @@ jobs: runs-on: ubuntu-latest steps: - name: "Build:checkout" - uses: actions/checkout@v2 - - name: Build and Publish latest Docker image - uses: VaultVulp/gp-docker-action@1.2.0 + uses: actions/checkout@v3 with: - github-token: ${{ secrets.GITHUB_TOKEN }} - image-name: android-sdk-env + fetch-depth: 0 + - name: 'Get Previous tag' + id: previoustag + uses: "WyriHaximus/github-action-get-previous-tag@v1" + with: + fallback: v0.0.0 + - name: Publish to Registry + uses: elgohr/Publish-Docker-Github-Action@v4 + with: + name: ${{github.repository}}/android-env + password: ${{ secrets.GITHUB_TOKEN }} + username: ${{ github.actor }} + registry: ghcr.io dockerfile: android/ci/Dockerfile_env + tags: latest,${{ steps.previoustag.outputs.tag }} diff --git a/.github/workflows/android-hicn.yml b/.github/workflows/android-hicn.yml new file mode 100644 index 0000000..fe079fc --- /dev/null +++ b/.github/workflows/android-hicn.yml @@ -0,0 +1,48 @@ +############################################################################# + # Copyright (c) 2022 Cisco and/or its affiliates. + # Licensed under the Apache License, Version 2.0 (the "License"); + # you may not use this file except in compliance with the License. + # You may obtain a copy of the License at: + # + # http://www.apache.org/licenses/LICENSE-2.0 + # + # Unless required by applicable law or agreed to in writing, software + # distributed under the License is distributed on an "AS IS" BASIS, + # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + # See the License for the specific language governing permissions and + # limitations under the License. + ############################################################################## + +name: Docker Android Hicn + +on: + schedule: + - cron: '0 * * * *' + push: + branches: + - main + +jobs: + build: + name: 'Build' + runs-on: ubuntu-latest + steps: + - name: "Build:checkout" + uses: actions/checkout@v3 + with: + fetch-depth: 0 + - name: 'Get Previous tag' + id: previoustag + uses: "WyriHaximus/github-action-get-previous-tag@v1" + with: + fallback: v0.0.0 + - name: Publish to Registry + uses: elgohr/Publish-Docker-Github-Action@v4 + with: + name: ${{github.repository}}/android-hicn + password: ${{ secrets.GITHUB_TOKEN }} + username: ${{ github.actor }} + registry: ghcr.io + dockerfile: android/ci/Dockerfile_hicn + buildargs: BASE_IMAGE=ghcr.io/${{github.repository}}/android-dep:latest + tags: latest,${{ steps.previoustag.outputs.tag }} \ No newline at end of file diff --git a/.github/workflows/master.yml b/.github/workflows/master.yml new file mode 100644 index 0000000..94ad85f --- /dev/null +++ b/.github/workflows/master.yml @@ -0,0 +1,90 @@ +############################################################################# +# Copyright (c) 2022 Cisco and/or its affiliates. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at: +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +############################################################################## + +name: Master Branch Job + +on: + push: + branches: + - main + +env: + REGISTRY: ghcr.io + IMAGE_NAME: ${{ github.repository }} + +jobs: + Master: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + with: + ref: "${{ github.event.pull_request.head.ref }}" + repository: "${{ github.event.pull_request.head.repo.full_name}}" + token: "${{ secrets.HICN_ACTIONS_TOKEN }}" + fetch-depth: 0 + - name: run + id: run + run: | + echo $GITHUB_SHA + if git describe --tags --exact-match $GITHUB_SHA; then + echo ::set-output name=istag::'true' + else + echo ::set-output name=istag::'false' + fi + git describe --tags --exact-match $GITHUB_SHA | true + PROMOTE=$(echo "${{ github.event.head_commit.message }}" | \ + grep -e "#promote" | \ + awk '$0 ~ /#promote/ { print "promote" }') + PROMOTE_LEVEL=$(echo "${{ github.event.head_commit.message }}" | \ + grep -E "#promote MAJOR|MINOR|PATCH" | \ + awk -F '#promote' '{print $2}' | \ + awk -F ' ' '{print $1}') + echo ::set-output name=promote::$PROMOTE + echo ::set-output name=promote-level::$PROMOTE_LEVEL + - name: 'Get Previous tag' + id: previoustag + uses: "WyriHaximus/github-action-get-previous-tag@v1" + with: + fallback: v0.0.0 + - name: Create bump and changelog + id: cz + if: "!startsWith(github.event.head_commit.message, 'bump:') && steps.run.outputs.promote == 'promote' && steps.run.outputs.promote-level != ''" + uses: commitizen-tools/commitizen-action@master + with: + github_token: ${{ secrets.HICN_ACTIONS_TOKEN }} + increment: ${{ steps.run.outputs.promote-level }} + push: true + changelog: true + - name: Print Version + if: "!startsWith(github.event.head_commit.message, 'bump:') && steps.run.outputs.promote == 'promote' && steps.run.outputs.promote-level != ''" + run: echo "Bumped to version ${{ steps.cz.outputs.version }}" + - name: Build and push aar libraries + if: "startsWith(github.event.head_commit.message, 'bump:') && steps.run.outputs.istag == 'true'" + uses: elgohr/Publish-Docker-Github-Action@v4 + env: + BASE_IMAGE: ghcr.io/${{github.repository}}/android-hicn:latest + GITHUB_USERNAME: ${{ secrets.HICN_BOT }} + GITHUB_PASSWORD: ${{ secrets.HICN_ACTIONS_TOKEN }} + GITHUB_MVN_REPO: 'https://maven.pkg.github.com/${{github.repository}}' + VERSION: ${{ steps.previoustag.outputs.tag }} + with: + name: ${{github.repository}}/android-build-aar + username: ${{ env.GITHUB_USERNAME }} + password: ${{ env.GITHUB_PASSWORD }} + registry: ghcr.io + dockerfile: android/ci/Dockerfile + buildargs: BASE_IMAGE,GITHUB_USERNAME,GITHUB_PASSWORD,GITHUB_MVN_REPO,VERSION + no_push: true + context: android diff --git a/.github/workflows/verify.yml b/.github/workflows/verify.yml index 36b4ab2..0c2429c 100644 --- a/.github/workflows/verify.yml +++ b/.github/workflows/verify.yml @@ -13,6 +13,8 @@ # limitations under the License. ############################################################################## +name: Very job for Android + on: pull_request: types: @@ -24,23 +26,34 @@ env: IMAGE_NAME: ${{ github.repository }} jobs: - test: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - with: - ref: "${{ github.event.pull_request.head.ref }}" - repository: "${{ github.event.pull_request.head.repo.full_name}}" - fetch-depth: 0 - - name: Capture commit id - id: capture - run: | - COMMIT_ID="$(git rev-parse "${{ github.head_ref }}")" - echo "The sha of the starting commit is $COMMIT_ID" - echo "::set-output name=commit::$COMMIT_ID" - - name: Check commits - uses: manang/commitizen-check@v0.0.1 - - name: compile docker - id: compile - run: | - bash android/ci/docker-build.sh + Verify: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + with: + ref: "${{ github.event.pull_request.head.ref }}" + repository: "${{ github.event.pull_request.head.repo.full_name}}" + fetch-depth: 0 + - name: Capture commit id + id: capture + run: | + COMMIT_ID="$(git rev-parse "${{ github.head_ref }}")" + echo "The sha of the starting commit is $COMMIT_ID" + echo "::set-output name=commit::$COMMIT_ID" + - name: Check commits + uses: manang/commitizen-check@v0.0.1 + - name: Verify + uses: elgohr/Publish-Docker-Github-Action@v4 + env: + BASE_IMAGE: ghcr.io/${{github.repository}}/android-hicn:latest + GITHUB_USERNAME: ${{ github.actor }} + GITHUB_PASSWORD: ${{ secrets.GITHUB_TOKEN }} + with: + name: ${{github.repository}}/android-verify + username: ${{ env.GITHUB_USERNAME }} + password: ${{ env.GITHUB_PASSWORD }} + registry: ghcr.io + dockerfile: android/ci/Dockerfile_verify + buildargs: BASE_IMAGE + no_push: true + context: android diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..31ee23a --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,31 @@ +## v0.0.4 (2022-10-27) + +### Feat + +- change credentials github registry to push public docker images (#36) + +## v0.0.3 (2022-10-27) + +### Feat + +- publish android aar to packages (#34) + +## v0.0.2 (2022-10-26) + +### Feat + +- add multi stage docker images (#33) + +### Fix + +- **master.yml**: remove personal token (#26) + +## v0.0.1 (2022-10-19) + +### Feat + +- version if promote #promote PATCH (#21) +- **cmake**: warnings old version of cmake, 3.22 needed, 3.18 installed (#20) +- check if commit is conventional commit compliant (#17) +- upgrade dockerfiles to compile environment+dependencies+hicn libraries (#14) +- upgrade android-sdk to support arm64 (#13) diff --git a/android/.gitignore b/android/.gitignore index 58001c5..4e2b78d 100644 --- a/android/.gitignore +++ b/android/.gitignore @@ -1,2 +1,10 @@ hicn-aar/FaceMgrLibrary/facemgrLibrary/.cxx hicn-aar/ForwarderLibrary/facemgrLibrary/.cxx +.distillery.stamp +.versions +build_aarch64 +build_x86_64 +sdk +src +usr_aarch64 +usr_x86_64 diff --git a/android/CommonLibrary/build.gradle b/android/CommonLibrary/build.gradle index 62418d9..f719677 100644 --- a/android/CommonLibrary/build.gradle +++ b/android/CommonLibrary/build.gradle @@ -15,7 +15,10 @@ buildscript { ext { - VERSION = '1' + MVN_REPO = '' + A_USER = '' + A_PASSWORD = '' + VERSION_NUMBER = 'v0.0.10' } repositories { diff --git a/android/CommonLibrary/common/build.gradle b/android/CommonLibrary/common/build.gradle index 5763dd0..b6cb0d8 100644 --- a/android/CommonLibrary/common/build.gradle +++ b/android/CommonLibrary/common/build.gradle @@ -6,14 +6,13 @@ buildscript { } dependencies { classpath 'com.android.tools.build:gradle:4.2.2' - //classpath 'com.android.tools.build:gradle:3.0.0' classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.8.4' } } plugins { id 'com.android.library' - id 'maven-publish' + id("maven-publish") } @@ -25,11 +24,11 @@ android { minSdkVersion 28 targetSdkVersion 30 versionCode 1 - versionName "1.0" + versionName getProjectProperty('VERSION_NUMBER') testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" consumerProguardFiles "consumer-rules.pro" - buildConfigField "String", "VERSION", "\"" + this.properties['VERSION']?.trim() + "\"" + buildConfigField "String", "VERSION", "\"" + this.properties['VERSION_NUMBER']?.trim() + "\"" } buildTypes { @@ -46,22 +45,13 @@ android { libraryVariants.all { variant -> variant.outputs.each { output -> - output.outputFileName = "common-${variant.name}-${defaultConfig.versionName}-${defaultConfig.versionCode}.aar" + output.outputFileName = "hicn-common-${variant.name}-${defaultConfig.versionName}-${defaultConfig.versionCode}.aar" } } } -def getVersionCode_() { - - if ("${getProjectProperty('VERSION_CODE')}".isEmpty()) - return 5 - else { - return "${getProjectProperty('VERSION_CODE')}".toInteger() - } -} - def getVersion() { if ("${getProjectProperty('VERSION')}".isEmpty()) @@ -73,7 +63,7 @@ def getVersion() { def String getProjectProperty(String propertyName) { - String value = "1" + String value = "v0.0.0" if (hasProperty(propertyName)) { value = this.properties[propertyName] @@ -81,38 +71,37 @@ def String getProjectProperty(String propertyName) return value } -// publishing { -// repositories { -// maven { -// name = 'GitHubPackages' -// url = uri(project.findProperty('MVN_REPO')) -// credentials { -// username = project.findProperty('A_USER') -// password = project.findProperty('A_PASSWORD') -// } -// } - -// } - -// afterEvaluate { -// publications { -// release(MavenPublication) { -// from components.release - -// groupId = 'com.cisco.hicn' -// version = project.findProperty('VERSION') -// artifactId 'common' -// } -// debug(MavenPublication) { -// from components.debug - -// groupId = 'com.cisco.hicn' -// version = project.findProperty('VERSION') -// artifactId 'common-debug' -// } -// } -// } -// } +publishing { + repositories { + maven { + name = 'GitHubPackages' + url = project.findProperty('MVN_REPO') + credentials { + username = project.findProperty('A_USER') + password = project.findProperty('A_PASSWORD') + } + } + + } + + afterEvaluate { + publications { + release(MavenPublication) { + from components.release + + groupId = 'com.cisco.hicn' + version = getProjectProperty('VERSION_NUMBER') + artifactId 'hicn-common' + } + debug(MavenPublication) { + from components.debug + groupId = 'com.cisco.hicn' + version = getProjectProperty('VERSION_NUMBER') + artifactId 'hicn-common-debug' + } + } + } +} dependencies { implementation 'androidx.appcompat:appcompat:1.2.0' diff --git a/android/CommonLibrary/gradle.properties b/android/CommonLibrary/gradle.properties index 6dd0218..f728266 100644 --- a/android/CommonLibrary/gradle.properties +++ b/android/CommonLibrary/gradle.properties @@ -16,3 +16,6 @@ android.useAndroidX=true # This option should only be used with decoupled projects. More details, visit # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects # org.gradle.parallel=true + +GITHUB_ACTOR=manang +GITHUB_TOKEN=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 \ No newline at end of file diff --git a/android/ci/Dockerfile b/android/ci/Dockerfile index bd014dd..cbe3111 100644 --- a/android/ci/Dockerfile +++ b/android/ci/Dockerfile @@ -13,29 +13,27 @@ # limitations under the License. ############################################################################## -FROM ubuntu:22.04 as android-sdk-dep +ARG BASE_IMAGE=ubuntu:22.04 +FROM $BASE_IMAGE -ENV TZ=Europe/Paris -RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone -RUN apt update && apt install -y build-essential openjdk-11-jdk git autoconf libtool wget unzip python3 -RUN wget -c https://services.gradle.org/distributions/gradle-7.4.2-bin.zip -P /tmp \ - && unzip -d /opt/gradle /tmp/gradle-7.4.2-bin.zip \ - && rm /tmp/gradle-7.4.2-bin.zip \ - && echo export GRADLE_HOME=/opt/gradle/gradle-7.4.2 >> /etc/profile.d/gradle.sh \ - && echo export PATH=/opt/gradle/gradle-7.4.2/bin:${PATH} >> /etc/profile.d/gradle.sh \ - && cat /etc/profile.d/gradle.sh \ - && chmod +x /etc/profile.d/gradle.sh \ - && . /etc/profile.d/gradle.sh \ - && gradle --version -ENV PATH=/opt/gradle/gradle-7.4.2/bin:${PATH} +MAINTAINER Angelo Mantellini + +ARG GITHUB_USERNAME +ARG GITHUB_PASSWORD +ARG GITHUB_MVN_REPO +ARG VERSION +ENV A_USERNAME=$GITHUB_USERNAME +ENV A_PASSWORD=$GITHUB_PASSWORD +ENV GITHUB_MVN_REPO=$GITHUB_MVN_REPO +ENV VERSION=$VERSION COPY . /android-sdk WORKDIR /android-sdk -RUN make init_sdk && ./compileAll.sh && rm -rf sdk/commandlinetools*.zip && bash compileDep.sh && rm -rf src build* -FROM android-sdk-dep as android-sdk-build -RUN gradle --version -RUN echo sdk.dir=`pwd`/sdk > CommonLibrary/local.properties && cd CommonLibrary && gradle compileReleaseSources -RUN make android_facemgrlibraryaar -RUN make android_forwarderlibraryaar +RUN echo sdk.dir=`pwd`/sdk > CommonLibrary/local.properties && cd CommonLibrary \ + && gradle publish -PA_USER=${A_USERNAME} -PA_PASSWORD=${A_PASSWORD} -PVERSION_NUMBER=${VERSION} -PMODULE_SRC='0' -PMVN_REPO=${GITHUB_MVN_REPO} +RUN echo sdk.dir=`pwd`/sdk > hicn-aar/FaceMgrLibrary/local.properties && cd hicn-aar && cd FaceMgrLibrary \ + && gradle publish -PA_USER=${A_USERNAME} -PA_PASSWORD=${A_PASSWORD} -PVERSION_NUMBER=${VERSION} -PMODULE_SRC='0' -PMVN_REPO=${GITHUB_MVN_REPO} +RUN echo sdk.dir=`pwd`/sdk > hicn-aar/ForwarderLibrary/local.properties && cd hicn-aar && cd ForwarderLibrary \ + && gradle publish -PA_USER=${A_USERNAME} -PA_PASSWORD=${A_PASSWORD} -PVERSION_NUMBER=${VERSION} -PMODULE_SRC='0' -PMVN_REPO=${GITHUB_MVN_REPO} diff --git a/android/ci/Dockerfile_dep b/android/ci/Dockerfile_dep new file mode 100644 index 0000000..d6565be --- /dev/null +++ b/android/ci/Dockerfile_dep @@ -0,0 +1,25 @@ +############################################################################# +# Copyright (c) 2022 Cisco and/or its affiliates. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at: +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +############################################################################## + +ARG BASE_IMAGE=ubuntu:22.04 +FROM $BASE_IMAGE + +MAINTAINER Angelo Mantellini + +COPY android /android-sdk + +WORKDIR /android-sdk + +RUN bash compileDep.sh &&rm -rf $(ls| grep -v 'sdk\|usr_aarch64\|usr_x86_64') \ No newline at end of file diff --git a/android/ci/Dockerfile_env b/android/ci/Dockerfile_env index 4335906..6002f03 100644 --- a/android/ci/Dockerfile_env +++ b/android/ci/Dockerfile_env @@ -20,20 +20,20 @@ MAINTAINER Angelo Mantellini ENV VERBOSE=1 RUN apt update && apt install -y build-essential openjdk-11-jdk git autoconf libtool wget unzip python3 && apt clean -RUN wget -c https://services.gradle.org/distributions/gradle-7.4.2-bin.zip -P /tmp \ - && unzip -d /opt/gradle /tmp/gradle-7.4.2-bin.zip \ - && rm /tmp/gradle-7.4.2-bin.zip \ - && echo export GRADLE_HOME=/opt/gradle/gradle-7.4.2 >> /etc/profile.d/gradle.sh \ - && echo export PATH=/opt/gradle/gradle-7.4.2/bin:${PATH} >> /etc/profile.d/gradle.sh \ +RUN wget -c https://services.gradle.org/distributions/gradle-7.5.1-bin.zip -P /tmp \ + && unzip -d /opt/gradle /tmp/gradle-7.5.1-bin.zip \ + && rm /tmp/gradle-7.5.1-bin.zip \ + && echo export GRADLE_HOME=/opt/gradle/gradle-7.5.1 >> /etc/profile.d/gradle.sh \ + && echo export PATH=/opt/gradle/gradle-7.5.1/bin:${PATH} >> /etc/profile.d/gradle.sh \ && cat /etc/profile.d/gradle.sh \ && chmod +x /etc/profile.d/gradle.sh \ && . /etc/profile.d/gradle.sh \ && gradle --version -ENV PATH=/opt/gradle/gradle-7.4.2/bin:${PATH} +ENV PATH=/opt/gradle/gradle-7.5.1/bin:${PATH} COPY android /android-sdk WORKDIR /android-sdk -RUN bash compileDep.sh && rm -rf sdk/commandlinetools-mac-8512546_latest.zip && rm -rf usr_* src build_* && ls \ No newline at end of file +RUN make init_sdk && rm -rf sdk/commandlinetools-mac-8512546_latest.zip && rm -rf $(ls -1 | grep -v 'sdk') \ No newline at end of file diff --git a/android/ci/Dockerfile_hicn b/android/ci/Dockerfile_hicn new file mode 100644 index 0000000..b9d0e64 --- /dev/null +++ b/android/ci/Dockerfile_hicn @@ -0,0 +1,27 @@ +############################################################################# +# Copyright (c) 2022 Cisco and/or its affiliates. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at: +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. +############################################################################## + +ARG BASE_IMAGE=ubuntu:22.04 +FROM $BASE_IMAGE + +MAINTAINER Angelo Mantellini + +COPY android /android-sdk + +WORKDIR /android-sdk + +RUN ls +RUN bash compileHicn.sh &&rm -rf $(ls| grep -v 'sdk\|usr_aarch64\|usr_x86_64') +RUN ls \ No newline at end of file diff --git a/android/ci/Dockerfile_verify b/android/ci/Dockerfile_verify new file mode 100644 index 0000000..154af95 --- /dev/null +++ b/android/ci/Dockerfile_verify @@ -0,0 +1,37 @@ + ############################################################################# + # Copyright (c) 2022 Cisco and/or its affiliates. + # Licensed under the Apache License, Version 2.0 (the "License"); + # you may not use this file except in compliance with the License. + # You may obtain a copy of the License at: + # + # http://www.apache.org/licenses/LICENSE-2.0 + # + # Unless required by applicable law or agreed to in writing, software + # distributed under the License is distributed on an "AS IS" BASIS, + # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + # See the License for the specific language governing permissions and + # limitations under the License. + ############################################################################## + +ARG BASE_IMAGE=ubuntu:22.04 +FROM $BASE_IMAGE + +MAINTAINER Angelo Mantellini + +ARG GITHUB_USERNAME +ARG GITHUB_PASSWORD +ARG GITHUB_MVN_REPO +ARG VERSION +ENV A_USERNAME=$GITHUB_USERNAME +ENV A_PASSWORD=$GITHUB_PASSWORD +ENV GITHUB_MVN_REPO=$GITHUB_MVN_REPO +ENV VERSION=$VERSION + +COPY . /android-sdk + +WORKDIR /android-sdk + +RUN gradle --version +RUN echo sdk.dir=`pwd`/sdk > CommonLibrary/local.properties && cd CommonLibrary && gradle compileReleaseSources +RUN make android_facemgrlibraryaar +RUN make android_forwarderlibraryaar \ No newline at end of file diff --git a/android/ci/docker-build.sh b/android/ci/docker-build.sh index e998bb9..f042fbc 100755 --- a/android/ci/docker-build.sh +++ b/android/ci/docker-build.sh @@ -23,18 +23,13 @@ echo "**********************************************************" echo "******************* Compilation *************************" echo "***********************************************************" -ANDRODI_SDK_DEP=android-sdk-dep -ANDRODI_SDK_BUILD=android-sdk-build - -docker build --no-cache --progress=plain \ - --target ${ANDRODI_SDK_DEP} \ - -t ${ANDRODI_SDK_DEP} \ - -f android/ci/Dockerfile \ - android +ANDROID_SDK_DEP=android-sdk-dep +ANDROID_SDK_BUILD=android-sdk-build docker build \ --progress=plain \ - --target ${ANDRODI_SDK_BUILD} \ - -t ${ANDRODI_SDK_BUILD} \ + --target ${ANDROID_SDK_BUILD} \ + -t ${ANDROID_SDK_BUILD} \ + --build-arg BASE_IMAGE \ -f android/ci/Dockerfile \ android diff --git a/android/ci/docker-publish.sh b/android/ci/docker-publish.sh new file mode 100755 index 0000000..82baf15 --- /dev/null +++ b/android/ci/docker-publish.sh @@ -0,0 +1,37 @@ + ############################################################################# + # Copyright (c) 2022 Cisco and/or its affiliates. + # Licensed under the Apache License, Version 2.0 (the "License"); + # you may not use this file except in compliance with the License. + # You may obtain a copy of the License at: + # + # http://www.apache.org/licenses/LICENSE-2.0 + # + # Unless required by applicable law or agreed to in writing, software + # distributed under the License is distributed on an "AS IS" BASIS, + # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + # See the License for the specific language governing permissions and + # limitations under the License. + ############################################################################## + +#!/bin/bash + +set -e +set -x +set -o pipefail + +echo "**********************************************************" +echo "******************* Compilation *************************" +echo "***********************************************************" + +ANDROID_SDK_DEP=android-sdk-dep +ANDROID_SDK_PUBLISH=android-sdk-build +HICN_AAR_PUBLISH=android-sdk-publish + +docker build \ + -t ${HICN_AAR_PUBLISH} \ + --target ${HICN_AAR_PUBLISH} \ + --build-arg GITHUB_USERNAME \ + --build-arg GITHUB_PASSWORD \ + --build-arg GITHUB_MVN_REPO \ + -f android/ci/Dockerfile \ + android diff --git a/android/compileHicn.sh b/android/compileHicn.sh index a09f99e..c8454a6 100755 --- a/android/compileHicn.sh +++ b/android/compileHicn.sh @@ -1,7 +1,7 @@ #!/bin/bash set -e -make download-hicn +make init_sdk download-hicn export ANDROID_ARCH="arm64" make compile-hicn export ANDROID_ARCH="x86_64" diff --git a/android/config/config.mk b/android/config/config.mk index cf2fc67..c69d33e 100644 --- a/android/config/config.mk +++ b/android/config/config.mk @@ -164,7 +164,7 @@ export ANDROID_COMPILE_SDK=30 export ANDROID_BUILD_TOOLS=30.0.2 export ANDROID_SDK_TOOLS_REV=8512546 export ANDROID_CMAKE_REV=3.6.4111459 -export ANDROID_CMAKE_REV_3_18=3.18.1 +export ANDROID_CMAKE_REV_3_22=3.22.1 export VERSIONS_FILE=${DISTILLERY_ROOT_DIR}/.versions export HICN_COMMIT=master export BLACKLIST_FILE=$(shell pwd)/config/blacklistfile diff --git a/android/config/modules/002-cmake-modules.mk b/android/config/modules/002-cmake-modules.mk index 0463e52..6391a73 100644 --- a/android/config/modules/002-cmake-modules.mk +++ b/android/config/modules/002-cmake-modules.mk @@ -24,7 +24,7 @@ ${$1_BUILD_DIR}/Makefile: ${$1_SOURCE_DIR}/CMakeLists.txt ${DISTILLERY_STAMP} echo ${$1_BUILD_DIR}; cd ${$1_BUILD_DIR}; \ DEPENDENCY_HOME=${DISTILLERY_EXTERN_DIR} \ - ${SDK}/cmake/${ANDROID_CMAKE_REV_3_18}/bin/cmake \ # -DCMAKE_TOOLCHAIN_FILE=${NDK}/build/cmake/android.toolchain.cmake \ + ${SDK}/cmake/${ANDROID_CMAKE_REV_3_22}/bin/cmake \ # -DCMAKE_TOOLCHAIN_FILE=${NDK}/build/cmake/android.toolchain.cmake \ -DANDROID_TOOLCHAIN=clang -DANDROID_STL=c++_static \ -DANDROID_ABI=${ANDROID_ABI} \ #ANDROID_STANDALONE_TOOLCHAIN_SEARCH_PATH=${DISTILLERY_ROOT_DIR}/sdk/toolchain_${ABI} \ -DCMAKE_BUILD_TYPE=Release \ diff --git a/android/hICNTools/app/build.gradle b/android/hICNTools/app/build.gradle index 5b7bb9a..9e46dca 100644 --- a/android/hICNTools/app/build.gradle +++ b/android/hICNTools/app/build.gradle @@ -62,7 +62,7 @@ android { externalNativeBuild { cmake { path "src/main/cpp/CMakeLists.txt" - version "3.18.1" + version "3.22.1" } } } diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common b/android/hicn-aar/FaceMgrLibrary/aar/common new file mode 120000 index 0000000..996d802 --- /dev/null +++ b/android/hicn-aar/FaceMgrLibrary/aar/common @@ -0,0 +1 @@ +../../../CommonLibrary/common \ No newline at end of file diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common/.gitignore b/android/hicn-aar/FaceMgrLibrary/aar/common/.gitignore deleted file mode 100644 index 42afabf..0000000 --- a/android/hicn-aar/FaceMgrLibrary/aar/common/.gitignore +++ /dev/null @@ -1 +0,0 @@ -/build \ No newline at end of file diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common/build.gradle b/android/hicn-aar/FaceMgrLibrary/aar/common/build.gradle deleted file mode 100644 index 5763dd0..0000000 --- a/android/hicn-aar/FaceMgrLibrary/aar/common/build.gradle +++ /dev/null @@ -1,124 +0,0 @@ - -buildscript { - repositories { - mavenCentral() - google() - } - dependencies { - classpath 'com.android.tools.build:gradle:4.2.2' - //classpath 'com.android.tools.build:gradle:3.0.0' - classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.8.4' - } -} - -plugins { - id 'com.android.library' - id 'maven-publish' -} - - - -android { - compileSdkVersion 30 - - defaultConfig { - minSdkVersion 28 - targetSdkVersion 30 - versionCode 1 - versionName "1.0" - - testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" - consumerProguardFiles "consumer-rules.pro" - buildConfigField "String", "VERSION", "\"" + this.properties['VERSION']?.trim() + "\"" - } - - buildTypes { - release { - minifyEnabled false - proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' - - } - } - compileOptions { - sourceCompatibility JavaVersion.VERSION_1_8 - targetCompatibility JavaVersion.VERSION_1_8 - } - - libraryVariants.all { variant -> - variant.outputs.each { output -> - output.outputFileName = "common-${variant.name}-${defaultConfig.versionName}-${defaultConfig.versionCode}.aar" - } - } - -} - - -def getVersionCode_() { - - if ("${getProjectProperty('VERSION_CODE')}".isEmpty()) - return 5 - else { - return "${getProjectProperty('VERSION_CODE')}".toInteger() - } -} - -def getVersion() { - - if ("${getProjectProperty('VERSION')}".isEmpty()) - return "1.0" - else { - return "${getProjectProperty('VERSION')}" - } -} - -def String getProjectProperty(String propertyName) -{ - String value = "1" - if (hasProperty(propertyName)) - { - value = this.properties[propertyName] - } - return value -} - -// publishing { -// repositories { -// maven { -// name = 'GitHubPackages' -// url = uri(project.findProperty('MVN_REPO')) -// credentials { -// username = project.findProperty('A_USER') -// password = project.findProperty('A_PASSWORD') -// } -// } - -// } - -// afterEvaluate { -// publications { -// release(MavenPublication) { -// from components.release - -// groupId = 'com.cisco.hicn' -// version = project.findProperty('VERSION') -// artifactId 'common' -// } -// debug(MavenPublication) { -// from components.debug - -// groupId = 'com.cisco.hicn' -// version = project.findProperty('VERSION') -// artifactId 'common-debug' -// } -// } -// } -// } - -dependencies { - implementation 'androidx.appcompat:appcompat:1.2.0' - implementation 'com.google.android.material:material:1.2.1' - testImplementation 'junit:junit:4.+' - androidTestImplementation 'androidx.test.ext:junit:1.1.2' - androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0' - -} diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common/consumer-rules.pro b/android/hicn-aar/FaceMgrLibrary/aar/common/consumer-rules.pro deleted file mode 100644 index e69de29..0000000 diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common/proguard-rules.pro b/android/hicn-aar/FaceMgrLibrary/aar/common/proguard-rules.pro deleted file mode 100644 index 481bb43..0000000 --- a/android/hicn-aar/FaceMgrLibrary/aar/common/proguard-rules.pro +++ /dev/null @@ -1,21 +0,0 @@ -# Add project specific ProGuard rules here. -# You can control the set of applied configuration files using the -# proguardFiles setting in build.gradle. -# -# For more details, see -# http://developer.android.com/guide/developing/tools/proguard.html - -# If your project uses WebView with JS, uncomment the following -# and specify the fully qualified class name to the JavaScript interface -# class: -#-keepclassmembers class fqcn.of.javascript.interface.for.webview { -# public *; -#} - -# Uncomment this to preserve the line number information for -# debugging stack traces. -#-keepattributes SourceFile,LineNumberTable - -# If you keep the line number information, uncomment this to -# hide the original source file name. -#-renamesourcefileattribute SourceFile \ No newline at end of file diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common/src/androidTest/java/hicn/cisco/common/ExampleInstrumentedTest.java b/android/hicn-aar/FaceMgrLibrary/aar/common/src/androidTest/java/hicn/cisco/common/ExampleInstrumentedTest.java deleted file mode 100644 index d867bcd..0000000 --- a/android/hicn-aar/FaceMgrLibrary/aar/common/src/androidTest/java/hicn/cisco/common/ExampleInstrumentedTest.java +++ /dev/null @@ -1,26 +0,0 @@ -package hicn.cisco.common; - -import android.content.Context; - -import androidx.test.platform.app.InstrumentationRegistry; -import androidx.test.ext.junit.runners.AndroidJUnit4; - -import org.junit.Test; -import org.junit.runner.RunWith; - -import static org.junit.Assert.*; - -/** - * Instrumented test, which will execute on an Android device. - * - * @see Testing documentation - */ -@RunWith(AndroidJUnit4.class) -public class ExampleInstrumentedTest { - @Test - public void useAppContext() { - // Context of the app under test. - Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext(); - assertEquals("hicn.cisco.common.test", appContext.getPackageName()); - } -} \ No newline at end of file diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/AndroidManifest.xml b/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/AndroidManifest.xml deleted file mode 100644 index 75fb830..0000000 --- a/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/AndroidManifest.xml +++ /dev/null @@ -1,5 +0,0 @@ - - - - \ No newline at end of file diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/java/com/cisco/hicn/common/CommonUtility.java b/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/java/com/cisco/hicn/common/CommonUtility.java deleted file mode 100644 index 6ee65cf..0000000 --- a/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/java/com/cisco/hicn/common/CommonUtility.java +++ /dev/null @@ -1,7 +0,0 @@ -package com.cisco.hicn.common; - -public class CommonUtility { - public static String getAndroidSdkVersion() { - return BuildConfig.VERSION; - } -} diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/java/com/cisco/hicn/common/NetworkServiceHelper.java b/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/java/com/cisco/hicn/common/NetworkServiceHelper.java deleted file mode 100644 index bd3c08d..0000000 --- a/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/java/com/cisco/hicn/common/NetworkServiceHelper.java +++ /dev/null @@ -1,144 +0,0 @@ -/* - * Copyright (c) 2019 Cisco and/or its affiliates. - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at: - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package com.cisco.hicn.common; -import android.content.Context; -import android.net.ConnectivityManager; -import android.net.LinkAddress; -import android.net.LinkProperties; -import android.net.Network; -import android.net.NetworkCapabilities; -import android.net.NetworkRequest; -import android.util.Log; -import androidx.annotation.NonNull; -import java.net.Inet4Address; - -public class NetworkServiceHelper { - private static final String TAG = "Hicn." + NetworkServiceHelper.class.getSimpleName(); - - private ConnectivityManager mConMan; - private SocketBinder mSocketBinder; - private ConnectivityManager.NetworkCallback mMobileNetworkCallback; - private ConnectivityManager.NetworkCallback mWifiNetworkCallback; - - public void init(Context ctx, SocketBinder socketBinder) { - mConMan = (ConnectivityManager) ctx.getApplicationContext().getSystemService(Context.CONNECTIVITY_SERVICE); - mSocketBinder = socketBinder; - - requestMobileNetwork(); - requestWifiNetwork(); - } - - public void clear() { - if (mConMan != null) { - if (mMobileNetworkCallback != null) { - mConMan.unregisterNetworkCallback(mMobileNetworkCallback); - mMobileNetworkCallback = null; - Log.i(TAG, "Mobile network released"); - } - if (mWifiNetworkCallback != null) { - mConMan.unregisterNetworkCallback(mWifiNetworkCallback); - mWifiNetworkCallback = null; - Log.i(TAG, "Wi-Fi network released"); - } - } - } - - private void requestMobileNetwork() { - final int[] transportTypes = new int[]{NetworkCapabilities.TRANSPORT_CELLULAR}; - final int[] capabilities = new int[]{NetworkCapabilities.NET_CAPABILITY_INTERNET, NetworkCapabilities.NET_CAPABILITY_NOT_VPN}; - - if (mMobileNetworkCallback != null) { - Log.d(TAG, "Already mobile network requested"); - return; - } - mMobileNetworkCallback = new ConnectivityManager.NetworkCallback() { - @Override - public void onAvailable(Network network) { - mSocketBinder.addNetwork(getIfname(transportTypes, capabilities), network); - } - }; - - Log.i(TAG, "Request mobile network"); - requestPreferredNetworksWith(transportTypes, capabilities, mMobileNetworkCallback); - } - - private void requestWifiNetwork() { - final int[] transportTypes = new int[]{NetworkCapabilities.TRANSPORT_WIFI}; - final int[] capabilities = new int[]{NetworkCapabilities.NET_CAPABILITY_INTERNET, NetworkCapabilities.NET_CAPABILITY_NOT_VPN}; - - - if (mWifiNetworkCallback != null) { - Log.d(TAG, "Already Wi-Fi network requested"); - return; - } - mWifiNetworkCallback = new ConnectivityManager.NetworkCallback() { - @Override - public void onAvailable(Network network) { - mSocketBinder.addNetwork(getIfname(transportTypes, capabilities), network); - } - }; - - Log.i(TAG, "Request Wi-Fi network"); - requestPreferredNetworksWith(transportTypes, capabilities, mWifiNetworkCallback); - } - - private void requestPreferredNetworksWith(@NonNull int[] transportTypes, @NonNull int[] capabilities, - @NonNull ConnectivityManager.NetworkCallback callback) { - NetworkRequest.Builder builder = new NetworkRequest.Builder(); - - for (int trans : transportTypes) - builder.addTransportType(trans); - - for (int cap : capabilities) - builder.addCapability(cap); - - NetworkRequest request = builder.build(); - mConMan.requestNetwork(request, callback); - } - - private boolean hasAllFlags(NetworkCapabilities nc, - @NonNull int[] transportTypes, @NonNull int[] capabilities) { - for (int t : transportTypes) { - if (!nc.hasTransport(t)) - return false; - } - for (int c : capabilities) { - if (!nc.hasCapability(c)) - return false; - } - return true; - } - - private String getIfname(@NonNull int[] transportTypes, @NonNull int[] capabilities) { - String ifname = ""; - - final Network[] networks = mConMan.getAllNetworks(); - for (final Network nw : networks) { - NetworkCapabilities nc = mConMan.getNetworkCapabilities(nw); - if (hasAllFlags(nc, transportTypes, capabilities)) { - LinkProperties lp = mConMan.getLinkProperties(nw); - Log.d(TAG, "iface: " + lp.toString()); - for (LinkAddress addr : lp.getLinkAddresses()) { - if (addr.getAddress() instanceof Inet4Address) { - ifname = lp.getInterfaceName(); - break; - } - } - } - } - return ifname; - } -} diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/java/com/cisco/hicn/common/SocketBinder.java b/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/java/com/cisco/hicn/common/SocketBinder.java deleted file mode 100644 index d13b286..0000000 --- a/android/hicn-aar/FaceMgrLibrary/aar/common/src/main/java/com/cisco/hicn/common/SocketBinder.java +++ /dev/null @@ -1,80 +0,0 @@ -/* - * Copyright (c) 2019 Cisco and/or its affiliates. - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at: - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -package com.cisco.hicn.common; - -import android.net.Network; -import android.util.Log; - -import java.io.FileDescriptor; -import java.io.IOException; -import java.lang.reflect.Field; -import java.util.ArrayList; -import java.util.Collections; -import java.util.Hashtable; - -public class SocketBinder { - private static final String TAG = "Hicn." + SocketBinder.class.getSimpleName(); - private Hashtable mNetworks = new Hashtable<>(); - - public void addNetwork(String ifname, Network network) { - Log.i(TAG, "Network added: " + ifname); - mNetworks.put(ifname, network); - } - - public int getNumberOfNetworks() { - return mNetworks.size(); - } - - public ArrayList getAllNetworkNames() { - return Collections.list(mNetworks.keys()); - } - - public Network getNetwork(String ifname) { - return mNetworks.get(ifname); - } - - public boolean bindSocket(int sock, String ifname) { - boolean ret = false; - - Network network = mNetworks.get(ifname); - if (network != null) - ret = bindSocket(sock, network); - - Log.i(TAG, "bindSocket(" + sock + ", " + ifname + ")=" + ret); - return ret; - } - - private boolean bindSocket(int sock, Network network) { - try { - FileDescriptor fd = new FileDescriptor(); - Field field = FileDescriptor.class.getDeclaredField("descriptor"); - field.setAccessible(true); - field.setInt(fd, sock); - field.setAccessible(false); - - network.bindSocket(fd); - return true; - } catch (SecurityException | IllegalArgumentException - | NoSuchFieldException | IllegalAccessException e) { - e.printStackTrace(); - Log.e(TAG, e.toString()); - } catch (IOException e) { - e.printStackTrace(); - Log.e(TAG, e.toString()); - } - return false; - } -} diff --git a/android/hicn-aar/FaceMgrLibrary/aar/common/src/test/java/hicn/cisco/common/ExampleUnitTest.java b/android/hicn-aar/FaceMgrLibrary/aar/common/src/test/java/hicn/cisco/common/ExampleUnitTest.java deleted file mode 100644 index 7697a6c..0000000 --- a/android/hicn-aar/FaceMgrLibrary/aar/common/src/test/java/hicn/cisco/common/ExampleUnitTest.java +++ /dev/null @@ -1,17 +0,0 @@ -package hicn.cisco.common; - -import org.junit.Test; - -import static org.junit.Assert.*; - -/** - * Example local unit test, which will execute on the development machine (host). - * - * @see Testing documentation - */ -public class ExampleUnitTest { - @Test - public void addition_isCorrect() { - assertEquals(4, 2 + 2); - } -} \ No newline at end of file diff --git a/android/hicn-aar/FaceMgrLibrary/build.gradle b/android/hicn-aar/FaceMgrLibrary/build.gradle index 646a6b2..dfbfac8 100644 --- a/android/hicn-aar/FaceMgrLibrary/build.gradle +++ b/android/hicn-aar/FaceMgrLibrary/build.gradle @@ -13,17 +13,22 @@ * limitations under the License. */ + + buildscript { ext { MODULE_SRC = '1' - VERSION = '1' + A_USER = '' + A_PASSWORD = '' + MVN_REPO = '' + VERSION_NUMBER = 'v0.0.10' } repositories { google() mavenCentral() } dependencies { - classpath 'com.android.tools.build:gradle:4.1.1' + classpath 'com.android.tools.build:gradle:7.2.2' } } diff --git a/android/hicn-aar/FaceMgrLibrary/facemgrLibrary/build.gradle b/android/hicn-aar/FaceMgrLibrary/facemgrLibrary/build.gradle index 23ee2c7..a8568f0 100644 --- a/android/hicn-aar/FaceMgrLibrary/facemgrLibrary/build.gradle +++ b/android/hicn-aar/FaceMgrLibrary/facemgrLibrary/build.gradle @@ -1,8 +1,7 @@ - buildscript { repositories { - mavenCentral() google() + mavenCentral() } dependencies { classpath 'com.android.tools.build:gradle:7.0.4' @@ -17,7 +16,6 @@ plugins { apply from: '../../properties.gradle' - android { compileSdkVersion 30 @@ -43,7 +41,8 @@ android { include 'arm64-v8a', 'x86_64' } } - buildConfigField "String", "VERSION", "\"" + this.properties['VERSION']?.trim() + "\"" + + buildConfigField "String", "VERSION", "\"" + this.properties['VERSION_NUMBER']?.trim() + "\"" } buildTypes { @@ -61,13 +60,13 @@ android { externalNativeBuild { cmake { path "src/main/cpp/CMakeLists.txt" - version "3.18.1" + version "3.22.1" } } libraryVariants.all { variant -> variant.outputs.each { output -> - output.outputFileName = "facemgrlibrary-${getVersion()}.aar" + output.outputFileName = "hicnfacemgrlibrary-${getVersion()}.aar" } } @@ -85,10 +84,10 @@ def getVersionCode_() { def getVersion() { - if ("${getProjectProperty('VERSION')}".isEmpty()) + if ("${getProjectProperty('VERSION_NUMBER')}".isEmpty()) return "1.0" else { - return "${getProjectProperty('VERSION')}" + return "${getProjectProperty('VERSION_NUMBER')}" } } @@ -102,34 +101,64 @@ def String getProjectProperty(String propertyName) return value } -// publishing { +publishing { + if (Integer.parseInt(this.properties['MODULE_SRC']) == 0) { + repositories { + maven { + name = 'GitHubPackages' + url = project.findProperty('MVN_REPO') + credentials { + username = project.findProperty('A_USER') + password = project.findProperty('A_PASSWORD') + } + } + } -// afterEvaluate { -// publications { -// release(MavenPublication) { -// from components.release -// groupId = 'com.cisco.hicn' -// version = project.findProperty('VERSION') -// artifactId 'facemgr' -// } -// debug(MavenPublication) { -// from components.debug + afterEvaluate { + publications { + release(MavenPublication) { + from components.release -// groupId = 'com.cisco.hicn' -// version = project.findProperty('VERSION') -// artifactId 'facemgr-debug' -// } -// } -// } -// } + groupId = 'com.cisco.hicn' + version = project.findProperty('VERSION_NUMBER') + artifactId 'hicnfacemgr' + } + debug(MavenPublication) { + from components.debug + + groupId = 'com.cisco.hicn' + version = project.findProperty('VERSION_NUMBER') + artifactId 'hicnfacemgr-debug' + } + } + } + } +} + +repositories { + if (Integer.parseInt(this.properties['MODULE_SRC']) == 0) { + maven { + name = 'Artifactory' + url = uri(this.properties['MVN_REPO']) + credentials { + username = this.properties["A_USER"] + password = this.properties["A_PASSWORD"] + } + } + } +} dependencies { - implementation project(":aar:common") + if (Integer.parseInt(this.properties['MODULE_SRC']) == 0) { + implementation 'com.cisco.hicn:hicn-common:' + project.findProperty('VERSION_NUMBER') + } else { + implementation project(":aar:common") + } implementation 'androidx.appcompat:appcompat:1.2.0' implementation 'com.google.android.material:material:1.2.1' testImplementation 'junit:junit:4.+' androidTestImplementation 'androidx.test.ext:junit:1.1.2' androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0' -} +} \ No newline at end of file diff --git a/android/hicn-aar/FaceMgrLibrary/settings.gradle b/android/hicn-aar/FaceMgrLibrary/settings.gradle index 5f52e5d..fcf8fcf 100644 --- a/android/hicn-aar/FaceMgrLibrary/settings.gradle +++ b/android/hicn-aar/FaceMgrLibrary/settings.gradle @@ -1,3 +1,4 @@ -include ':aar:common' +if(Integer.parseInt(getProperties().get("MODULE_SRC")) == 1) { + include ':aar:common' +} include ':facemgrLibrary' - diff --git a/android/hicn-aar/ForwarderLibrary/aar/common/build.gradle b/android/hicn-aar/ForwarderLibrary/aar/common/build.gradle index 5763dd0..c5ea46d 100644 --- a/android/hicn-aar/ForwarderLibrary/aar/common/build.gradle +++ b/android/hicn-aar/ForwarderLibrary/aar/common/build.gradle @@ -81,38 +81,38 @@ def String getProjectProperty(String propertyName) return value } -// publishing { -// repositories { -// maven { -// name = 'GitHubPackages' -// url = uri(project.findProperty('MVN_REPO')) -// credentials { -// username = project.findProperty('A_USER') -// password = project.findProperty('A_PASSWORD') -// } -// } - -// } - -// afterEvaluate { -// publications { -// release(MavenPublication) { -// from components.release - -// groupId = 'com.cisco.hicn' -// version = project.findProperty('VERSION') -// artifactId 'common' -// } -// debug(MavenPublication) { -// from components.debug - -// groupId = 'com.cisco.hicn' -// version = project.findProperty('VERSION') -// artifactId 'common-debug' -// } -// } -// } -// } +publishing { + repositories { + maven { + name = 'GitHubPackages' + url = uri(project.findProperty('MVN_REPO')) + credentials { + username = project.findProperty('A_USER') + password = project.findProperty('A_PASSWORD') + } + } + + } + + afterEvaluate { + publications { + release(MavenPublication) { + from components.release + + groupId = 'com.cisco.hicn' + version = project.findProperty('VERSION_NUMBER') + artifactId 'common' + } + debug(MavenPublication) { + from components.debug + + groupId = 'com.cisco.hicn' + version = project.findProperty('VERSION_NUMBER') + artifactId 'common-debug' + } + } + } +} dependencies { implementation 'androidx.appcompat:appcompat:1.2.0' @@ -120,5 +120,4 @@ dependencies { testImplementation 'junit:junit:4.+' androidTestImplementation 'androidx.test.ext:junit:1.1.2' androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0' - } diff --git a/android/hicn-aar/ForwarderLibrary/build.gradle b/android/hicn-aar/ForwarderLibrary/build.gradle index d4e5f3e..9240722 100644 --- a/android/hicn-aar/ForwarderLibrary/build.gradle +++ b/android/hicn-aar/ForwarderLibrary/build.gradle @@ -18,15 +18,15 @@ buildscript { MODULE_SRC = '1' A_USER = '' A_PASSWORD = '' - MVN_REPO = 'https://engci-maven-master.cisco.com/artifactory/maqy-maven-release' - VERSION = '1' + MVN_REPO = '' + VERSION_NUMBER = 'v0.0.10' } repositories { google() mavenCentral() } dependencies { - classpath 'com.android.tools.build:gradle:4.1.1' + classpath 'com.android.tools.build:gradle:7.2.2' } } diff --git a/android/hicn-aar/ForwarderLibrary/gradle.properties b/android/hicn-aar/ForwarderLibrary/gradle.properties index 6dd0218..7873815 100644 --- a/android/hicn-aar/ForwarderLibrary/gradle.properties +++ b/android/hicn-aar/ForwarderLibrary/gradle.properties @@ -16,3 +16,4 @@ android.useAndroidX=true # This option should only be used with decoupled projects. More details, visit # http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects # org.gradle.parallel=true + diff --git a/android/hicn-aar/ForwarderLibrary/hicnforwarderLibrary/build.gradle b/android/hicn-aar/ForwarderLibrary/hicnforwarderLibrary/build.gradle index cd4bc0d..f5c70dc 100644 --- a/android/hicn-aar/ForwarderLibrary/hicnforwarderLibrary/build.gradle +++ b/android/hicn-aar/ForwarderLibrary/hicnforwarderLibrary/build.gradle @@ -42,7 +42,7 @@ android { } } - buildConfigField "String", "VERSION", "\"" + this.properties['VERSION']?.trim() + "\"" + buildConfigField "String", "VERSION", "\"" + this.properties['VERSION_NUMBER']?.trim() + "\"" } buildTypes { @@ -60,7 +60,7 @@ android { externalNativeBuild { cmake { path "src/main/cpp/CMakeLists.txt" - version "3.18.1" + version "3.22.1" } } @@ -84,10 +84,10 @@ def getVersionCode_() { def getVersion() { - if ("${getProjectProperty('VERSION')}".isEmpty()) + if ("${getProjectProperty('VERSION_NUMBER')}".isEmpty()) return "1.0" else { - return "${getProjectProperty('VERSION')}" + return "${getProjectProperty('VERSION_NUMBER')}" } } @@ -102,54 +102,59 @@ def String getProjectProperty(String propertyName) } publishing { - repositories { - maven { - name = 'Artifactory' - url = uri(project.findProperty('MVN_REPO')) - credentials { - username = project.findProperty('A_USER') - password = project.findProperty('A_PASSWORD') + if (Integer.parseInt(this.properties['MODULE_SRC']) == 0) { + repositories { + maven { + name = 'Artifactory' + url = uri(project.findProperty('MVN_REPO')) + credentials { + username = project.findProperty('A_USER') + password = project.findProperty('A_PASSWORD') + } } - } - - } - afterEvaluate { - publications { - release(MavenPublication) { - from components.release - - groupId = 'com.cisco.hicn' - version = project.findProperty('VERSION') - artifactId 'hicnforwarder' - } - debug(MavenPublication) { - from components.debug + } - groupId = 'com.cisco.hicn' - version = project.findProperty('VERSION') - artifactId 'hicnforwarder-debug' + afterEvaluate { + publications { + release(MavenPublication) { + from components.release + + groupId = 'com.cisco.hicn' + version = project.findProperty('VERSION_NUMBER') + artifactId 'hicnforwarder' + } + debug(MavenPublication) { + from components.debug + + groupId = 'com.cisco.hicn' + version = project.findProperty('VERSION_NUMBER') + artifactId 'hicnforwarder-debug' + } } } } } repositories { - maven { - name = 'Artifactory' - url = uri(this.properties['MVN_REPO']) - credentials { - username = this.properties["A_USER"] - password = this.properties["A_PASSWORD"] + if (Integer.parseInt(this.properties['MODULE_SRC']) == 0) { + maven { + name = 'Artifactory' + url = uri(this.properties['MVN_REPO']) + credentials { + username = this.properties["A_USER"] + password = this.properties["A_PASSWORD"] + } } } } dependencies { if (Integer.parseInt(this.properties['MODULE_SRC']) == 0) { - implementation 'com.cisco.hicn:common:' + common + implementation 'com.cisco.hicn:hicn-common:' + project.findProperty('VERSION_NUMBER') } else { implementation project(":aar:common") + } implementation 'androidx.appcompat:appcompat:1.2.0' implementation 'com.google.android.material:material:1.2.1' diff --git a/android/hicn-aar/ForwarderLibrary/settings.gradle b/android/hicn-aar/ForwarderLibrary/settings.gradle index e5cb39a..e172694 100644 --- a/android/hicn-aar/ForwarderLibrary/settings.gradle +++ b/android/hicn-aar/ForwarderLibrary/settings.gradle @@ -1,2 +1,5 @@ -include ':aar:common' +if(Integer.parseInt(getProperties().get("MODULE_SRC")) == 1) { + include ':aar:common' +} + include ':hicnforwarderLibrary' \ No newline at end of file diff --git a/android/scripts/compile_facemgr_aar.sh b/android/scripts/compile_facemgr_aar.sh index d996141..c42590b 100644 --- a/android/scripts/compile_facemgr_aar.sh +++ b/android/scripts/compile_facemgr_aar.sh @@ -24,20 +24,20 @@ done cd hicn-aar/FaceMgrLibrary if [ ! -f local.properties ]; then - echo sdk.dir=${SDK} > local.properties - echo ndk.dir=${NDK} >> local.properties + echo sdk.dir=${SDK} > local.properties + echo ndk.dir=${NDK} >> local.properties fi if [ "$ENABLE_DEBUG" = "DEBUG" ]; then - ASSEMBLE="compileDebugSources" + ASSEMBLE="compileDebugSources" else - ASSEMBLE="compileReleaseSources" + ASSEMBLE="compileReleaseSources" fi if [ "$MVN_REPO" = "" ]; then - gradle $ASSEMBLE -PVERSION=$VERSION_CODE + gradle $ASSEMBLE -PVERSION=$VERSION_CODE -PMODULE_SRC=1 else - gradle $ASSEMBLE -PENABLE_HPROXY=$ENABLE_HPROXY + gradle $ASSEMBLE -PMODULE_SRC=1 fi cd .. diff --git a/android/scripts/compile_hicnforwarder_aar.sh b/android/scripts/compile_hicnforwarder_aar.sh index 918aeff..22308ca 100644 --- a/android/scripts/compile_hicnforwarder_aar.sh +++ b/android/scripts/compile_hicnforwarder_aar.sh @@ -36,9 +36,9 @@ else fi if [ "$MVN_REPO" = "" ]; then - gradle $ASSEMBLE -PVERSION=$VERSION_CODE + gradle $ASSEMBLE -PVERSION=$VERSION_CODE -PMODULE_SRC=1 else - gradle $ASSEMBLE -PENABLE_HPROXY=$ENABLE_HPROXY + gradle $ASSEMBLE -PMODULE_SRC=1 fi diff --git a/android/scripts/init_sdk.sh b/android/scripts/init_sdk.sh index 41c2e69..3f4b0ff 100755 --- a/android/scripts/init_sdk.sh +++ b/android/scripts/init_sdk.sh @@ -61,7 +61,7 @@ if [ -z ${NDK_PATH} ]; then echo yes | cmdline-tools/bin/sdkmanager --sdk_root=`pwd` 'platform-tools' echo yes | cmdline-tools/bin/sdkmanager --sdk_root=`pwd` 'build-tools;'$ANDROID_BUILD_TOOLS echo yes | cmdline-tools/bin/sdkmanager --sdk_root=`pwd` 'cmake;'$ANDROID_CMAKE_REV - echo yes | cmdline-tools/bin/sdkmanager --sdk_root=`pwd` --channel=3 --channel=1 'cmake;'$ANDROID_CMAKE_REV_3_18 + echo yes | cmdline-tools/bin/sdkmanager --sdk_root=`pwd` --channel=3 --channel=1 'cmake;'$ANDROID_CMAKE_REV_3_22 #echo yes | cmdline-tools/bin/sdkmanager --sdk_root=`pwd` 'ndk-bundle' echo yes | cmdline-tools/bin/sdkmanager --sdk_root=`pwd` "ndk;$ANDROID_NDK_VERSION" --channel=3 fi diff --git a/android/scripts/publish_common_aar.sh b/android/scripts/publish_common_aar.sh index 22c11be..de435c0 100755 --- a/android/scripts/publish_common_aar.sh +++ b/android/scripts/publish_common_aar.sh @@ -4,32 +4,33 @@ VERSION_CODE=1 GITHUB_USER="" GITHUB_TOKEN="" MVN_REPO="" -while getopts ":v:u:t:r:" opt; do - case $opt in - v) VERSION_CODE="$OPTARG" - ;; - u) GITHUB_USER="$OPTARG" - ;; - t) GITHUB_TOKEN="$OPTARG" - ;; - r) MVN_REPO="$OPTARG" - ;; - \?) echo "Invalid option -$OPTARG" >&2 - ;; - esac -done +# while getopts ":v:u:t:r:" opt; do +# case $opt in +# v) VERSION_CODE="$OPTARG" +# ;; +# u) GITHUB_USER="$OPTARG" +# ;; +# t) GITHUB_TOKEN="$OPTARG" +# ;; +# r) MVN_REPO="$OPTARG" +# ;; +# \?) echo "Invalid option -$OPTARG" >&2 +# ;; +# esac +# done -cd aar_modules/CommonLibrary +cd CommonLibrary if [ ! -f local.properties ]; then echo sdk.dir=${SDK} > local.properties fi -if [ "$MVN_REPO" = "" ]; then - ./gradlew publish -PVERSION=$VERSION_CODE -PGITHUB_USER=$GITHUB_USER -PGITHUB_TOKEN=$GITHUB_TOKEN -else - ./gradlew publish -PVERSION=$VERSION_CODE -PGITHUB_USER=$GITHUB_USER -PGITHUB_TOKEN=$GITHUB_TOKEN -PMVN_REPO=$MVN_REPO +#if [ "$MVN_REPO" = "" ]; then +# ./gradlew publish -PVERSION=$VERSION_CODE -PGITHUB_USER=$GITHUB_USER -PGITHUB_TOKEN=$GITHUB_TOKEN +#else + gradle publish -PVERSION=$VERSION_CODE + #-PGITHUB_USER=$GITHUB_USER -PGITHUB_TOKEN=$GITHUB_TOKEN -PMVN_REPO=$MVN_REPO fi echo "aar published" diff --git a/docker/Dockerfile.vswitch b/docker/Dockerfile.vswitch new file mode 100644 index 0000000..06cb2e8 --- /dev/null +++ b/docker/Dockerfile.vswitch @@ -0,0 +1,29 @@ +FROM ubuntu:20.04 + +SHELL ["/bin/bash", "-c"] +ARG DEBIAN_FRONTEND= + +RUN apt-get update +RUN apt-get install -y git ssh curl wget iproute2 + +# External the repos +RUN curl -s https://packagecloud.io/install/repositories/fdio/2202/script.deb.sh | bash +RUN curl -s https://packagecloud.io/install/repositories/fdio/hicn/script.deb.sh | bash + +RUN apt-get update && apt-get install -y \ + hicn-plugin \ + vpp-plugin-core \ + vpp \ + libvppinfra \ + libssh-4 \ + openssl \ + libpcre3 \ + iproute2 \ + iptables \ + frr \ + net-tools\ + iputils-ping \ + tini \ + && rm -rf /var/lib/apt/lists/* \ + && apt-get autoremove -y \ + && apt-get clean diff --git a/docker/tests/Dockerfile.host b/docker/tests/Dockerfile.host new file mode 100644 index 0000000..48b1cb2 --- /dev/null +++ b/docker/tests/Dockerfile.host @@ -0,0 +1,34 @@ +FROM ubuntu:20.04 + +ARG DEBIAN_FRONTEND= +RUN apt-get update +RUN apt-get install -y git ssh curl wget iproute2 +RUN curl -s https://packagecloud.io/install/repositories/fdio/2202/script.deb.sh | bash +RUN curl -s https://packagecloud.io/install/repositories/fdio/hicn/script.deb.sh | bash +RUN apt-get update && apt-get install -y \ + hicn-plugin \ + hicn-apps\ + vpp-plugin-core \ + vpp \ + libvppinfra \ + libssh-4 \ + openssl \ + libpcre3 \ + iproute2 \ + iptables \ + frr \ + net-tools\ + iputils-ping \ + tini \ + && rm -rf /var/lib/apt/lists/* \ + && apt-get autoremove -y \ + && apt-get clean + + +ARG HOST +COPY startup.conf /etc/vpp/ +COPY vpp-init-host${HOST}.txt /etc/vpp/vpp-init.txt + +WORKDIR /workspace +ENTRYPOINT ["/usr/bin/tini", "--"] +CMD ["/usr/lib/frr/frr-start.sh"] diff --git a/docker/tests/Dockerfile.router b/docker/tests/Dockerfile.router new file mode 100644 index 0000000..58f8644 --- /dev/null +++ b/docker/tests/Dockerfile.router @@ -0,0 +1,39 @@ +FROM ubuntu:20.04 + +ENV DEBIAN_FRONTEND=noninteractive +RUN apt-get update +RUN apt-get install -y git ssh curl wget iproute2 +RUN curl -s https://packagecloud.io/install/repositories/fdio/2202/script.deb.sh | bash +RUN curl -s https://packagecloud.io/install/repositories/fdio/hicn/script.deb.sh | bash +RUN apt-get update && apt-get install -y \ + hicn-plugin \ + vpp-plugin-core \ + vpp \ + libvppinfra \ + libssh-4 \ + openssl \ + libpcre3 \ + iproute2 \ + iptables \ + frr \ + net-tools\ + iputils-ping \ + tini \ + && rm -rf /var/lib/apt/lists/* \ + && apt-get autoremove -y \ + && apt-get clean + +RUN mkdir -p /var/run/frr +RUN chown -R frr:frr /etc/frr /var/run/frr +RUN mkdir -p /var/log/vpp +COPY daemons /etc/frr/ +COPY vtysh.conf /etc/frr/ +COPY frr-start.sh /usr/lib/frr/ +ARG ROUTER +COPY frr-router${ROUTER}.conf /etc/frr/frr.conf +COPY startup.conf /etc/vpp/ +COPY vpp-init-router${ROUTER}.txt /etc/vpp/vpp-init.txt +WORKDIR /workspace + +ENTRYPOINT ["/usr/bin/tini", "--"] +CMD ["/usr/lib/frr/frr-start.sh"] \ No newline at end of file diff --git a/docker/tests/README.md b/docker/tests/README.md new file mode 100644 index 0000000..417a3ae --- /dev/null +++ b/docker/tests/README.md @@ -0,0 +1,36 @@ +# Functional test description + +## Network topology +Host - H +Router - R +Linux Bridge - LB +VPP Router - VR + +LB1 - 10.1.0.0/16 +LB2 - 10.2.0.0/16 +LB3 - 10.3.0.0/16 + +### L2 Topology +H1 -- LB1 -- R1 -- LB2 - R2 -- LB3 -- H2 + +### L3 Topology +Host1 -- Router1 -- Router2 -- Host2 + +### Interfaces addressing at the linux bridge +* LB1 - 10.1.0.1/16 +* LB2 - 10.2.0.1/16 +* LB3 - 10.3.0.1/16 +* H1-1 - 10.1.0.2/16 +* R1-1 - 10.1.0.3/16 +* R1-2 - 10.2.0.2/16 +* R2-1 - 10.2.0.3/16 +* R2-2 - 10.3.0.2/16 +* H2-1 - 10.3.0.3/16 + +### VPP interfaces addresses +* H1-1 - 10.11.0.2/16 +* R1-1 - 10.11.0.3/16 +* R1-2 - 10.22.0.2/16 +* R2-1 - 10.22.0.3/16 +* R2-2 - 10.33.0.2/16 +* H2-1 - 10.33.0.3/16 diff --git a/docker/tests/daemons b/docker/tests/daemons new file mode 100644 index 0000000..04c21f1 --- /dev/null +++ b/docker/tests/daemons @@ -0,0 +1,85 @@ +# This file tells the frr package which daemons to start. +# +# Sample configurations for these daemons can be found in +# /usr/share/doc/frr/examples/. +# +# ATTENTION: +# +# When activating a daemon for the first time, a config file, even if it is +# empty, has to be present *and* be owned by the user and group "frr", else +# the daemon will not be started by /etc/init.d/frr. The permissions should +# be u=rw,g=r,o=. +# When using "vtysh" such a config file is also needed. It should be owned by +# group "frrvty" and set to ug=rw,o= though. Check /etc/pam.d/frr, too. +# +# The watchfrr, zebra and staticd daemons are always started. +# +bgpd=no +ospfd=yes +ospf6d=no +ripd=no +ripngd=no +isisd=no +pimd=no +ldpd=no +nhrpd=no +eigrpd=no +babeld=no +sharpd=no +pbrd=no +bfdd=no +fabricd=no +vrrpd=no + +# +# If this option is set the /etc/init.d/frr script automatically loads +# the config via "vtysh -b" when the servers are started. +# Check /etc/pam.d/frr if you intend to use "vtysh"! +# +vtysh_enable=yes +zebra_options=" -A 127.0.0.1 -s 90000000" +bgpd_options=" -A 127.0.0.1" +ospfd_options=" -A 127.0.0.1" +ospf6d_options=" -A ::1" +ripd_options=" -A 127.0.0.1" +ripngd_options=" -A ::1" +isisd_options=" -A 127.0.0.1" +pimd_options=" -A 127.0.0.1" +ldpd_options=" -A 127.0.0.1" +nhrpd_options=" -A 127.0.0.1" +eigrpd_options=" -A 127.0.0.1" +babeld_options=" -A 127.0.0.1" +sharpd_options=" -A 127.0.0.1" +pbrd_options=" -A 127.0.0.1" +staticd_options="-A 127.0.0.1" +bfdd_options=" -A 127.0.0.1" +fabricd_options="-A 127.0.0.1" +vrrpd_options=" -A 127.0.0.1" + +# configuration profile +# +#frr_profile="traditional" +#frr_profile="datacenter" + +# +# This is the maximum number of FD's that will be available. +# Upon startup this is read by the control files and ulimit +# is called. Uncomment and use a reasonable value for your +# setup if you are expecting a large number of peers in +# say BGP. +#MAX_FDS=1024 + +# The list of daemons to watch is automatically generated by the init script. +#watchfrr_options="" + +# To make watchfrr create/join the specified netns, use the following option: +#watchfrr_options="--netns" +# This only has an effect in /etc/frr//daemons, and you need to +# start FRR with "/usr/lib/frr/frrinit.sh start ". + +# for debugging purposes, you can specify a "wrap" command to start instead +# of starting the daemon directly, e.g. to use valgrind on ospfd: +# ospfd_wrap="/usr/bin/valgrind" +# or you can use "all_wrap" for all daemons, e.g. to use perf record: +# all_wrap="/usr/bin/perf record --call-graph -" +# the normal daemon command is added to this at the end. \ No newline at end of file diff --git a/docker/tests/docker-compose.yml b/docker/tests/docker-compose.yml new file mode 100644 index 0000000..7f75a8e --- /dev/null +++ b/docker/tests/docker-compose.yml @@ -0,0 +1,84 @@ +version: "3" +services: + host1: + build: + context: . + dockerfile: Dockerfile.host + args: + HOST: 1 + container_name: host1 + hostname: host1 + volumes: + - .:/workspace + networks: + - net1 + init: true + privileged: true + host2: + build: + context: . + dockerfile: Dockerfile.host + args: + HOST: 2 + container_name: host2 + hostname: host2 + volumes: + - .:/workspace + networks: + - net3 + init: true + privileged: true + router1: + build: + context: . + dockerfile: Dockerfile.router + args: + ROUTER: 1 + container_name: router1 + hostname: router1 + volumes: + - .:/workspace + networks: + - net1 + - net2 + privileged: true + depends_on: + - "host1" + - "host2" + router2: + build: + context: . + dockerfile: Dockerfile.router + args: + ROUTER: 2 + container_name: router2 + hostname: router2 + volumes: + - .:/workspace + networks: + - net2 + - net3 + privileged: true + depends_on: + - "host1" + - "host2" + - "router1" +networks: + net1: + driver: bridge + ipam: + driver: default + config: + - subnet: 10.1.0.0/16 + net2: + driver: bridge + ipam: + driver: default + config: + - subnet: 10.2.0.0/16 + net3: + driver: bridge + ipam: + driver: default + config: + - subnet: 10.3.0.0/16 \ No newline at end of file diff --git a/docker/tests/frr-router1.conf b/docker/tests/frr-router1.conf new file mode 100644 index 0000000..c958a06 --- /dev/null +++ b/docker/tests/frr-router1.conf @@ -0,0 +1,16 @@ +frr version 7.5_git +frr defaults traditional +hostname router1 +no ipv6 forwarding +service integrated-vtysh-config +! +interface lo + ip address 1.1.1.1/32 +! +router ospf + network 10.1.0.0/16 area 0.0.0.0 + network 10.2.0.0/16 area 0.0.0.0 + router-info area +! +line vty +! \ No newline at end of file diff --git a/docker/tests/frr-router2.conf b/docker/tests/frr-router2.conf new file mode 100644 index 0000000..0447162 --- /dev/null +++ b/docker/tests/frr-router2.conf @@ -0,0 +1,16 @@ +frr version 7.5_git +frr defaults traditional +hostname router1 +no ipv6 forwarding +service integrated-vtysh-config +! +interface lo + ip address 2.2.2.2/32 +! +router ospf + network 10.2.0.0/16 area 0.0.0.0 + network 10.3.0.0/16 area 0.0.0.0 + router-info area +! +line vty +! \ No newline at end of file diff --git a/docker/tests/frr-start.sh b/docker/tests/frr-start.sh new file mode 100755 index 0000000..63f330c --- /dev/null +++ b/docker/tests/frr-start.sh @@ -0,0 +1,4 @@ +#!/bin/bash +vpp -c /etc/vpp/startup.conf +source /usr/lib/frr/frrcommon.sh +/usr/lib/frr/watchfrr $(daemon_list) \ No newline at end of file diff --git a/docker/tests/host-start.sh b/docker/tests/host-start.sh new file mode 100644 index 0000000..63f330c --- /dev/null +++ b/docker/tests/host-start.sh @@ -0,0 +1,4 @@ +#!/bin/bash +vpp -c /etc/vpp/startup.conf +source /usr/lib/frr/frrcommon.sh +/usr/lib/frr/watchfrr $(daemon_list) \ No newline at end of file diff --git a/docker/tests/startup.conf b/docker/tests/startup.conf new file mode 100644 index 0000000..58ce201 --- /dev/null +++ b/docker/tests/startup.conf @@ -0,0 +1,22 @@ +cpu { main-core 1 } +plugins { + path /usr/lib/x86_64-linux-gnu/vpp_plugins:/usr/lib/vpp_plugins + plugin default { disable } + plugin acl_plugin.so { enable } + plugin dpdk_plugin.so { enable } + plugin memif_plugin.so { enable } + plugin hicn_plugin.so { enable } + plugin linux_cp_plugin.so { enable } + plugin ping_plugin.so { enable } +} + +unix { + startup-config /etc/vpp/vpp-init.txt + cli-listen /run/vpp/cli.sock + log /var/log/vpp/vpp.log +} + +linux-cp { + default netns dataplane + lcp-sync +} \ No newline at end of file diff --git a/docker/tests/supervisord.conf b/docker/tests/supervisord.conf new file mode 100644 index 0000000..7d6eb1d --- /dev/null +++ b/docker/tests/supervisord.conf @@ -0,0 +1,22 @@ +[supervisord] +nodaemon=true +logfile=/var/log/supervisord.log +loglevel=debug + +[program:vpp] +command=/usr/bin/vpp -c /etc/vpp/startup.conf +autorestart=true +redirect_stderr=true +priority=1 + +[program:watchfrr] +command=/usr/lib/frr/watchfrr -d -F traditional zebra staticd +autorestart=true +redirect_stderr=true +priority=2 + +[program:netopeer2-server] +command=/usr/bin/netopeer2-server -d +autorestart=true +redirect_stderr=true +priority=3 diff --git a/docker/tests/vpp-init-host1.txt b/docker/tests/vpp-init-host1.txt new file mode 100644 index 0000000..e85f5e6 --- /dev/null +++ b/docker/tests/vpp-init-host1.txt @@ -0,0 +1,4 @@ +create host-interface name eth0 +set interface state host-eth0 up +set int ip address host-eth0 10.11.0.2/16 +lcp create host-eth0 host-if e0 diff --git a/docker/tests/vpp-init-host2.txt b/docker/tests/vpp-init-host2.txt new file mode 100644 index 0000000..4eb85b4 --- /dev/null +++ b/docker/tests/vpp-init-host2.txt @@ -0,0 +1,4 @@ +create host-interface name eth0 +set interface state host-eth0 up +set int ip address host-eth0 10.33.0.3/16 +lcp create host-eth0 host-if e0 diff --git a/docker/tests/vpp-init-router1.txt b/docker/tests/vpp-init-router1.txt new file mode 100644 index 0000000..ee273e8 --- /dev/null +++ b/docker/tests/vpp-init-router1.txt @@ -0,0 +1,11 @@ +create host-interface name eth0 +create host-interface name eth1 + +set interface state host-eth0 up +set interface state host-eth1 up + +set int ip address host-eth0 10.11.0.3/16 +set int ip address host-eth1 10.22.0.2/16 + +lcp create host-eth0 host-if e0 +lcp create host-eth1 host-if e1 \ No newline at end of file diff --git a/docker/tests/vpp-init-router2.txt b/docker/tests/vpp-init-router2.txt new file mode 100644 index 0000000..21c1548 --- /dev/null +++ b/docker/tests/vpp-init-router2.txt @@ -0,0 +1,11 @@ +create host-interface name eth0 +create host-interface name eth1 + +set interface state host-eth0 up +set interface state host-eth1 up + +set int ip address host-eth0 10.22.0.3/16 +set int ip address host-eth1 10.33.0.2/16 + +lcp create host-eth0 host-if e0 +lcp create host-eth1 host-if e1 diff --git a/docker/tests/vtysh.conf b/docker/tests/vtysh.conf new file mode 100644 index 0000000..955f666 --- /dev/null +++ b/docker/tests/vtysh.conf @@ -0,0 +1,8 @@ +! +! Sample configuration file for vtysh. +! +!service integrated-vtysh-config +!hostname quagga-router +!username root nopassword +! +service integrated-vtysh-config \ No newline at end of file