From 134d3f98c9ebdb76cf2935f98150db243f20ba53 Mon Sep 17 00:00:00 2001 From: John Kleinschmidt Date: Tue, 27 Feb 2018 12:08:27 -0500 Subject: [PATCH 1/2] Allow CI building on arm64 hardware --- Dockerfile.arm64v8 | 63 ++++++++++++++++++++++++++++++++++++++++++ Jenkinsfile.arm64 | 35 +++++++++++++++++++++++ script/update-clang.sh | 8 +++++- spec/modules-spec.js | 3 +- 4 files changed, 107 insertions(+), 2 deletions(-) create mode 100644 Dockerfile.arm64v8 create mode 100644 Jenkinsfile.arm64 diff --git a/Dockerfile.arm64v8 b/Dockerfile.arm64v8 new file mode 100644 index 000000000000..2064f6f5d245 --- /dev/null +++ b/Dockerfile.arm64v8 @@ -0,0 +1,63 @@ +FROM arm64v8/ubuntu:16.04 + +RUN groupadd --gid 1000 builduser \ + && useradd --uid 1000 --gid builduser --shell /bin/bash --create-home builduser + +RUN groupadd --gid 114 jenkins \ + && useradd --uid 110 --gid jenkins --shell /bin/bash --create-home jenkins + +# Set up TEMP directory +ENV TEMP=/tmp +RUN chmod a+rwx /tmp + +RUN apt-get update && apt-get install -y\ + bison \ + build-essential \ + clang \ + curl \ + gperf \ + git \ + libasound2 \ + libasound2-dev \ + libcap-dev \ + libcups2-dev \ + libdbus-1-dev \ + libgconf-2-4 \ + libgconf2-dev \ + libgnome-keyring-dev \ + libgtk2.0-0 \ + libgtk2.0-dev \ + libgtk-3-0 \ + libgtk-3-dev \ + libnotify-dev \ + libnss3 \ + libnss3-dev \ + libx11-xcb-dev \ + libxss1 \ + libxtst-dev \ + libxtst6 \ + lsb-release \ + locales \ + ninja \ + python-setuptools \ + python-pip \ + python-dbusmock \ + wget \ + xvfb + +# Install node.js +RUN curl -sL https://deb.nodesource.com/setup_6.x | bash - +RUN apt-get update && apt-get install -y nodejs + +# Install crcmod +RUN pip install -U crcmod + +ADD tools/xvfb-init.sh /etc/init.d/xvfb +RUN chmod a+x /etc/init.d/xvfb + +# Install ninja in /usr/local +RUN cd /usr/local && git clone https://github.com/martine/ninja.git -b v1.5.3 +RUN cd /usr/local/ninja && ./configure.py --bootstrap + +USER builduser +WORKDIR /home/builduser diff --git a/Jenkinsfile.arm64 b/Jenkinsfile.arm64 new file mode 100644 index 000000000000..5639481d9d0f --- /dev/null +++ b/Jenkinsfile.arm64 @@ -0,0 +1,35 @@ +pipeline { + agent { + docker { + image 'electronbuilds/arm64v8:0.0.1' + args '--privileged' + } + } + environment { + TARGET_ARCH='arm64' + DISPLAY=':99.0' + } + stages { + stage('Bootstrap') { + steps { + sh 'script/bootstrap.py -v --dev --target_arch=$TARGET_ARCH' + } + } + stage('Build') { + steps { + sh 'script/build.py -c D --ninja-path /usr/local/ninja/ninja' + } + } + stage('Test') { + steps { + sh '/etc/init.d/xvfb start' + sh 'script/test.py --ci' + } + } + } + post { + always { + cleanWs() + } + } +} diff --git a/script/update-clang.sh b/script/update-clang.sh index 9a0a88dcb2e1..292e53244bcb 100755 --- a/script/update-clang.sh +++ b/script/update-clang.sh @@ -24,6 +24,7 @@ STAMP_FILE="${LLVM_DIR}/../llvm-build/cr_build_revision" LLVM_REPO_URL=${LLVM_URL:-https://llvm.org/svn/llvm-project} CDS_URL=https://commondatastorage.googleapis.com/chromium-browser-clang +S3_URL=https://s3.amazonaws.com/gh-contractor-zcbenz/clang # Die if any command dies, error on undefined variable expansions. @@ -49,7 +50,12 @@ CDS_FILE="clang-${PACKAGE_VERSION}.tgz" CDS_OUT_DIR=$(mktemp -d -t clang_download.XXXXXX) CDS_OUTPUT="${CDS_OUT_DIR}/${CDS_FILE}" if [ "${OS}" = "Linux" ]; then - CDS_FULL_URL="${CDS_URL}/Linux_x64/${CDS_FILE}" + ARCH="$(uname -m)" + if [ "${ARCH}" = "aarch64" ]; then + CDS_FULL_URL="${S3_URL}/arm64/${CDS_FILE}" + else + CDS_FULL_URL="${CDS_URL}/Linux_x64/${CDS_FILE}" + fi elif [ "${OS}" = "Darwin" ]; then CDS_FULL_URL="${CDS_URL}/Mac/${CDS_FILE}" fi diff --git a/spec/modules-spec.js b/spec/modules-spec.js index 88a625830c8d..b996b8f4839b 100644 --- a/spec/modules-spec.js +++ b/spec/modules-spec.js @@ -33,7 +33,8 @@ describe('modules support', () => { // https://github.com/electron/electron/issues/11274 xdescribe('ffi', () => { before(function () { - if (!nativeModulesEnabled || process.platform === 'win32') { + if (!nativeModulesEnabled || process.platform === 'win32' || + process.arch === 'arm64') { this.skip() } }) From 51f89048d6bda8b7f587c5da9518fb192ae7ebc1 Mon Sep 17 00:00:00 2001 From: Cheng Zhao Date: Thu, 8 Mar 2018 06:08:18 +0000 Subject: [PATCH 2/2] Use bundled freetype from Chromium --- brightray/brightray.gyp | 9 --------- vendor/libchromiumcontent | 2 +- 2 files changed, 1 insertion(+), 10 deletions(-) diff --git a/brightray/brightray.gyp b/brightray/brightray.gyp index ebd043845f4f..d72fcfba3808 100644 --- a/brightray/brightray.gyp +++ b/brightray/brightray.gyp @@ -161,7 +161,6 @@ '-ldl', '-lresolv', '-lfontconfig', - '-lfreetype', '-lexpat', ], }, @@ -173,14 +172,6 @@ ], }, }], - # On ARM64 libchromiumcontent always links to system libfreetype - ['target_arch=="arm64"', { - 'link_settings': { - 'libraries': [ - '-lfreetype', - ], - }, - }], ], }], # OS=="linux" ['OS=="mac"', { diff --git a/vendor/libchromiumcontent b/vendor/libchromiumcontent index 8c526e52d02a..f0d7c2dc0d44 160000 --- a/vendor/libchromiumcontent +++ b/vendor/libchromiumcontent @@ -1 +1 @@ -Subproject commit 8c526e52d02a574b6d3cbaf2014cdccb9a0e3185 +Subproject commit f0d7c2dc0d44960069a2d8b0a9f7c5722ceeb259