From fc06458038feaaeff4ef0f406f742cef4c7d1de2 Mon Sep 17 00:00:00 2001 From: Samuel Attard Date: Wed, 6 Feb 2019 12:53:25 -0800 Subject: [PATCH] ci: run lint on CircleCI (#16791) --- .circleci/config.yml | 44 ++++++++++++++++++++++++++++++++++++++++++++ .vsts/lint.yml | 31 ------------------------------- 2 files changed, 44 insertions(+), 31 deletions(-) delete mode 100644 .vsts/lint.yml diff --git a/.circleci/config.yml b/.circleci/config.yml index ba174ff490c..9e0dfe40c01 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -456,6 +456,39 @@ step-maybe-generate-typescript-defs: &step-maybe-generate-typescript-defs fi # Lists of steps. +steps-lint: &steps-lint + steps: + - *step-checkout-electron + - run: + name: Setup third_party Depot Tools + command: | + # "depot_tools" has to be checkout into "//third_party/depot_tools" so pylint.py can a "pylintrc" file. + git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git src/third_party/depot_tools + echo 'export PATH="$PATH:'"$PWD"'/src/third_party/depot_tools"' >> $BASH_ENV + - run: + name: Download GN Binary + command: | + chromium_revision="$(grep -A1 chromium_version src/electron/DEPS | tr -d '\n' | cut -d\' -f4)" + buildtools_revision="$(curl -sL "https://chromium.googlesource.com/chromium/src/+/${chromium_revision}/DEPS?format=TEXT" | base64 -d | grep buildtools_revision -A1 | tr -d '\n' | cut -d\' -f4)" + + git clone https://chromium.googlesource.com/chromium/buildtools "buildtools" + (cd "buildtools" && git checkout "$buildtools_revision") + echo 'export CHROMIUM_BUILDTOOLS_PATH="'"$PWD"'/buildtools"' >> $BASH_ENV + + download_from_google_storage --bucket chromium-gn -s "buildtools/linux64/gn.sha1" + - run: + name: Run Lint + command: | + # gn.py tries to find a gclient root folder starting from the current dir. + # When it fails and returns "None" path, the whole script fails. Let's "fix" it. + touch .gclient + # Another option would be to checkout "buildtools" inside the Electron checkout, + # but then we would lint its contents (at least gn format), and it doesn't pass it. + + cd src/electron + npm install + npm run lint + steps-checkout: &steps-checkout steps: - *step-checkout-electron @@ -732,6 +765,13 @@ chromium-upgrade-branches: &chromium-upgrade-branches # List of all jobs. version: 2 jobs: + # Layer 0: Lint. Standalone. + lint: + <<: *machine-linux-medium + environment: + <<: *env-linux-medium + <<: *steps-lint + # Layer 1: Checkout. linux-checkout: <<: *machine-linux-2xlarge @@ -1254,6 +1294,10 @@ jobs: workflows: version: 2 + lint: + jobs: + - lint + build-linux: jobs: - linux-checkout diff --git a/.vsts/lint.yml b/.vsts/lint.yml deleted file mode 100644 index 780c96cad70..00000000000 --- a/.vsts/lint.yml +++ /dev/null @@ -1,31 +0,0 @@ -pool: - vmImage: 'Ubuntu 16.04' - -steps: -- bash: | - # "depot_tools" has to be checkout into "//third_party/depot_tools" so pylint.py can a "pylintrc" file. - git clone https://chromium.googlesource.com/chromium/tools/depot_tools.git "${AGENT_BUILDDIRECTORY}/third_party/depot_tools" - echo "##vso[task.setvariable variable=PATH]$PATH:${AGENT_BUILDDIRECTORY}/third_party/depot_tools" - displayName: Setup Depot Tools - -- bash: | - chromium_revision="$(grep -A1 chromium_version DEPS | tr -d '\n' | cut -d\' -f4)" - buildtools_revision="$(curl -sL "https://chromium.googlesource.com/chromium/src/+/${chromium_revision}/DEPS?format=TEXT" | base64 -d | grep buildtools_revision -A1 | tr -d '\n' | cut -d\' -f4)" - - git clone https://chromium.googlesource.com/chromium/buildtools "${AGENT_TEMPDIRECTORY}/buildtools" - (cd "${AGENT_TEMPDIRECTORY}/buildtools" && git checkout "$buildtools_revision") - echo "##vso[task.setvariable variable=CHROMIUM_BUILDTOOLS_PATH]$AGENT_TEMPDIRECTORY/buildtools" - - download_from_google_storage --bucket chromium-gn -s "${AGENT_TEMPDIRECTORY}/buildtools/linux64/gn.sha1" - displayName: Download gn binary - -- bash: | - # gn.py tries to find a gclient root folder starting from the current dir. - # When it fails and returns "None" path, the whole script fails. Let's "fix" it. - touch .gclient - # Another option would be to checkout "buildtools" inside the Electron checkout, - # but then we would lint its contents (at least gn format), and it doesn't pass it. - - npm install - npm run lint - displayName: Run Lint