From 0973176db1cec04d7fdd81b0640539dfaa3124b7 Mon Sep 17 00:00:00 2001 From: Christian Nunciato Date: Mon, 20 May 2024 11:49:49 -0700 Subject: [PATCH] Add pre-commit linting, version checking --- .github/workflows/build-and-deploy.yml | 2 +- .github/workflows/check-links.yml | 2 +- .../customer-managed-deployment-agent-cli.yml | 2 +- .github/workflows/esc-cli.yml | 2 +- .github/workflows/generate-provider-docs.yml | 2 +- .github/workflows/pull-request.yml | 2 +- .github/workflows/pulumi-cli.yml | 2 +- .../workflows/testing-build-and-deploy.yml | 2 +- .husky/pre-commit | 2 ++ Makefile | 2 +- README.md | 10 +++--- config/_default/config.yml | 3 +- layouts/index.json | 26 +++++++------- layouts/page/about.html | 18 +++++----- layouts/page/leadership.html | 2 +- layouts/product/pulumi-cloud.html | 2 +- layouts/product/pulumi-insights.html | 2 +- package.json | 4 ++- scripts/ensure.sh | 36 ++++++++++++++----- scripts/format.sh | 5 +++ yarn.lock | 5 +++ 21 files changed, 84 insertions(+), 49 deletions(-) create mode 100644 .husky/pre-commit create mode 100755 scripts/format.sh diff --git a/.github/workflows/build-and-deploy.yml b/.github/workflows/build-and-deploy.yml index 58b0cf4ea1b2d..457ce99557a87 100644 --- a/.github/workflows/build-and-deploy.yml +++ b/.github/workflows/build-and-deploy.yml @@ -27,7 +27,7 @@ jobs: - uses: peaceiris/actions-hugo@v2 with: - hugo-version: '0.111.0' + hugo-version: '0.126.0' extended: true - name: Configure AWS Credentials diff --git a/.github/workflows/check-links.yml b/.github/workflows/check-links.yml index 9a560b58b5d10..be81ab92078b3 100644 --- a/.github/workflows/check-links.yml +++ b/.github/workflows/check-links.yml @@ -20,7 +20,7 @@ jobs: - name: Install Hugo uses: peaceiris/actions-hugo@v2 with: - hugo-version: '0.111.0' + hugo-version: '0.126.0' extended: true - name: Run make check_links run: make check_links diff --git a/.github/workflows/customer-managed-deployment-agent-cli.yml b/.github/workflows/customer-managed-deployment-agent-cli.yml index 1b3945d90bbd5..259b803be9f01 100644 --- a/.github/workflows/customer-managed-deployment-agent-cli.yml +++ b/.github/workflows/customer-managed-deployment-agent-cli.yml @@ -54,7 +54,7 @@ jobs: # - name: Install Hugo # uses: peaceiris/actions-hugo@v2 # with: -# hugo-version: '0.111.0' +# hugo-version: '0.126.0' # extended: true # - name: Install node # uses: actions/setup-node@v2 diff --git a/.github/workflows/esc-cli.yml b/.github/workflows/esc-cli.yml index 252b3477c7e89..8ccd810ad797e 100644 --- a/.github/workflows/esc-cli.yml +++ b/.github/workflows/esc-cli.yml @@ -53,7 +53,7 @@ jobs: - name: Install Hugo uses: peaceiris/actions-hugo@v2 with: - hugo-version: '0.111.0' + hugo-version: '0.126.0' extended: true - name: Install node uses: actions/setup-node@v2 diff --git a/.github/workflows/generate-provider-docs.yml b/.github/workflows/generate-provider-docs.yml index 5768a9af43f9f..2e54c33229db8 100644 --- a/.github/workflows/generate-provider-docs.yml +++ b/.github/workflows/generate-provider-docs.yml @@ -61,7 +61,7 @@ jobs: - name: Install Hugo uses: peaceiris/actions-hugo@v2 with: - hugo-version: '0.111.0' + hugo-version: '0.126.0' extended: true - name: setup node uses: actions/setup-node@v2 diff --git a/.github/workflows/pull-request.yml b/.github/workflows/pull-request.yml index f698cf31a353d..2a947e5e794a0 100644 --- a/.github/workflows/pull-request.yml +++ b/.github/workflows/pull-request.yml @@ -23,7 +23,7 @@ jobs: - uses: peaceiris/actions-hugo@v2 with: - hugo-version: '0.111.0' + hugo-version: '0.126.0' extended: true - name: Configure AWS Credentials diff --git a/.github/workflows/pulumi-cli.yml b/.github/workflows/pulumi-cli.yml index ef803e57b54d3..71e989090caab 100644 --- a/.github/workflows/pulumi-cli.yml +++ b/.github/workflows/pulumi-cli.yml @@ -56,7 +56,7 @@ jobs: - name: Install Hugo uses: peaceiris/actions-hugo@v2 with: - hugo-version: '0.111.0' + hugo-version: '0.126.0' extended: true - name: Install node uses: actions/setup-node@v2 diff --git a/.github/workflows/testing-build-and-deploy.yml b/.github/workflows/testing-build-and-deploy.yml index f381d3751ffda..7faf70164dfea 100644 --- a/.github/workflows/testing-build-and-deploy.yml +++ b/.github/workflows/testing-build-and-deploy.yml @@ -27,7 +27,7 @@ jobs: - uses: peaceiris/actions-hugo@v2 with: - hugo-version: '0.111.0' + hugo-version: '0.126.0' extended: true - name: Configure AWS Credentials diff --git a/.husky/pre-commit b/.husky/pre-commit new file mode 100644 index 0000000000000..d7c29f3c837cd --- /dev/null +++ b/.husky/pre-commit @@ -0,0 +1,2 @@ +echo "Running pre-commit checks..." +make lint diff --git a/Makefile b/Makefile index 70725a72f41fb..30e2d7fc13ec0 100644 --- a/Makefile +++ b/Makefile @@ -142,4 +142,4 @@ lint: .PHONY: format format: - yarn prettier --write . + ./scripts/format.sh diff --git a/README.md b/README.md index a8f0609feaab4..ac8324011e2d5 100644 --- a/README.md +++ b/README.md @@ -25,10 +25,10 @@ See also: We build the Pulumi website with Hugo, manage our dependencies with Node.js and Yarn, and write our documentation in Markdown. Below is a list of the tools you'll need if you'd like to work on the website (e.g., to contribute docs content, a blog post, etc.): -* [Hugo](https://gohugo.io) (>= 0.111.0) - * Hugo 0.111.0 is highly recommended. This is the version we use in our deployment pipelines. -* [Node.js](https://nodejs.org/en/) (>= 18) -* [Yarn](https://classic.yarnpkg.com/en/) (1.x) +* [Hugo](https://gohugo.io/installation/) (>= 0.126.0) + * Hugo 0.126.0 is highly recommended. This is the version we use in our deployment pipelines. +* [Node.js](https://nodejs.org/en/download/package-manager) (>= 18) +* [Yarn](https://classic.yarnpkg.com/lang/en/docs/install) (1.x) Additionally, to build the SDK and CLI documentation, you'll also need: @@ -125,7 +125,7 @@ pulumi gen-markdown ./content/docs/cli/commands # Generate Pulumi CLI documen esc gen-docs ./content/docs/esc-cli/commands # Generate Pulumi ESC CLI documentation. ``` -Generated docs reflect the functionality of the currently installed CLI, so make sure you've installed the latest public version of each one ([`pulumi`](https://github.com/pulumi/pulumi/releases), [`esc`](https://github.com/pulumi/esc/releases)) before running these commands and submitting your PR. +Generated docs reflect the functionality of the currently installed CLI, so make sure you've installed the latest public version of each one ([`pulumi`](https://github.com/pulumi/pulumi/releases), [`esc`](https://github.com/pulumi/esc/releases)) before running these commands and submitting your PR. ### Viewing rendered SDK and CLI docs locally diff --git a/config/_default/config.yml b/config/_default/config.yml index 7d963ef8b502d..ef5e68b35152c 100644 --- a/config/_default/config.yml +++ b/config/_default/config.yml @@ -13,8 +13,7 @@ security: - ALGOLIA_APP_SEARCH_KEY disableKinds: - - category - - taxonomyTerm + - taxonomy sectionPagesMenu: main pygmentsCodeFences: true diff --git a/layouts/index.json b/layouts/index.json index d3d2a7c1de170..3938177a86036 100644 --- a/layouts/index.json +++ b/layouts/index.json @@ -6,17 +6,19 @@ {{ $ancestors = $ancestors | append $a.LinkTitle }} {{- end -}} - {{- - $index = $index | append ( - dict - "objectID" $page.File.UniqueID - "title" $page.Title - "section" $page.Section - "href" $page.RelPermalink - "params" $page.Params - "kind" $page.Kind - "ancestors" (after 1 $ancestors) - ) - -}} + {{- if ne $page.File nil -}} + {{- + $index = $index | append ( + dict + "objectID" $page.File.UniqueID + "title" $page.Title + "section" $page.Section + "href" $page.RelPermalink + "params" $page.Params + "kind" $page.Kind + "ancestors" (after 1 $ancestors) + ) + -}} + {{- end -}} {{- end -}} {{- $index | jsonify (dict "indent" " ") -}} diff --git a/layouts/page/about.html b/layouts/page/about.html index b22d820d48038..885cf84df3fa8 100644 --- a/layouts/page/about.html +++ b/layouts/page/about.html @@ -57,7 +57,7 @@

We are Pulumi

Our purpose

To democratize the cloud for every engineer.

We help engineers ship infrastructure faster with Infrastructure as Code in general-purpose languages.

- Meet our leaders + Meet our leaders
@@ -98,7 +98,7 @@

{{ $value.title }}

-

Like what we stand for? Join us.

+

Like what we stand for? Join us.

We are looking for new teammates who want to build the future of cloud infrastructure together.

@@ -119,7 +119,7 @@

Pulumi is about community

Pulumipus wearing a medal with two hands raised
The Puluminaries

A group for stellar Pulumi community members who have made "above and beyond" contributions to the community.

- Meet our Puluminaries + Meet our Puluminaries
Pulumipus wearing a medal with two hands raised @@ -129,9 +129,9 @@

Pulumi is about community

Pulumipus wearing a Pulumi hoodie -
Pulumi users
+
Pulumi users

Engineers love Pulumi! Don’t believe us? Check out what our users have to say.

- Read user quotes + Read user quotes
@@ -226,7 +226,7 @@

Our awards & recognition

{{ end }}
- View all achievements + View all achievements
@@ -248,7 +248,7 @@
{{ .title }}
{{ end }} - View all press releases + View all press releases

Recent News

@@ -262,7 +262,7 @@
{{ .title }}
{{ end }} - View all recent news + View all recent news
@@ -275,6 +275,6 @@
{{ .title }}

Join our team

We are fully remote and hiring!

Our team is a diverse and talented group of individuals from all walks of life.

- Browse open positions + Browse open positions {{ end }} diff --git a/layouts/page/leadership.html b/layouts/page/leadership.html index 8f88634fd1bd6..395e75267c96e 100644 --- a/layouts/page/leadership.html +++ b/layouts/page/leadership.html @@ -4,7 +4,7 @@ {{ define "main" }}
- diff --git a/layouts/product/pulumi-cloud.html b/layouts/product/pulumi-cloud.html index 2e60a79359054..1a3a2493d10e5 100644 --- a/layouts/product/pulumi-cloud.html +++ b/layouts/product/pulumi-cloud.html @@ -151,7 +151,7 @@
{{ $item.title }}

{{ .title }}

{{ .description | markdownify }}

{{ end }} diff --git a/layouts/product/pulumi-insights.html b/layouts/product/pulumi-insights.html index eefb900929b53..6d9417a9f60c3 100644 --- a/layouts/product/pulumi-insights.html +++ b/layouts/product/pulumi-insights.html @@ -120,7 +120,7 @@

{{ .subtitle }}

{{ .title }}

{{ .description | markdownify }}

{{ end }} diff --git a/package.json b/package.json index ac50576e168b9..8e2f36f418434 100644 --- a/package.json +++ b/package.json @@ -4,7 +4,8 @@ "private": true, "license": "Apache-2.0", "scripts": { - "minify-css": "node scripts/minify-css.js" + "minify-css": "node scripts/minify-css.js", + "prepare": "husky" }, "dependencies": { "@aws-sdk/client-s3": "^3.427.0", @@ -34,6 +35,7 @@ "typescript": "^4.9.5" }, "devDependencies": { + "husky": "^9.0.11", "prettier": "^2.6.2" } } diff --git a/scripts/ensure.sh b/scripts/ensure.sh index 2f7b7cfd21a2f..57e78d9e7ef5a 100755 --- a/scripts/ensure.sh +++ b/scripts/ensure.sh @@ -1,14 +1,34 @@ #!/bin/bash -# Make sure the Node version matches what's in .nvmrc (and in our GitHub Actions workflows). -current_version="$(node -v)" -required_version="$(cat .nvmrc)" +set -o errexit -o pipefail -if [ ! $(echo ${current_version} | grep ${required_version}) ]; then - printf "\nIt looks like you're running Node %s, but this project uses Node %s.\n" ${current_version} ${required_version} - printf "If you're using nvm, try running nvm use.\n\n" - exit 1 -fi +check_version() { + tool_name="$1" + executable="$2" + version_string="$(eval $3)" + required_version="$4" + level="$5" + + color_red=$(echo -e "\033[0;31m") + color_yellow=$(echo -e "\033[0;33m") + color_end=$(echo -e "\033[0m") + + details="See the README at https://github.com/pulumi/docs for a list of required tools and versions." + + if ! command -v "$executable" &> /dev/null; then + echo -e "${color_red}error${color_end} This project requires $1, but the '$2' executable is either not installed or not on your PATH." + echo $details + exit 1 + fi + + if [ ! $(echo ${version_string} | grep ${required_version}) ]; then + printf "${color_yellow}warning${color_end} It looks like you're running %s %s, but this project uses version %s.\n" ${tool_name} ${version_string} ${required_version} + echo $details + fi +} +check_version "Node.js" "node" "node -v | sed 's/v\([0-9\.]*\).*$/\1/'" "18" +check_version "Hugo" "hugo" "hugo version | sed 's/hugo v\([0-9\.]*\).*$/\1/'" "0.126.0" +check_version "Yarn" "yarn" "yarn -v | sed 's/v\([0-9\.]*\).*$/\1/'" "1.22" # Install the Node dependencies for the website and the infrastructure. yarn install diff --git a/scripts/format.sh b/scripts/format.sh new file mode 100755 index 0000000000000..db8eabdb7570d --- /dev/null +++ b/scripts/format.sh @@ -0,0 +1,5 @@ +#!/bin/bash + +set -o errexit -o pipefail + +yarn prettier --write . diff --git a/yarn.lock b/yarn.lock index 934c9d39c427f..6d789733c2355 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2894,6 +2894,11 @@ humanize-duration@^3.9.1: resolved "https://registry.yarnpkg.com/humanize-duration/-/humanize-duration-3.27.3.tgz#db654e72ebf5ccfe232c7f56bc58aa3a6fe4df88" integrity sha512-iimHkHPfIAQ8zCDQLgn08pRqSVioyWvnGfaQ8gond2wf7Jq2jJ+24ykmnRyiz3fIldcn4oUuQXpjqKLhSVR7lw== +husky@^9.0.11: + version "9.0.11" + resolved "https://registry.yarnpkg.com/husky/-/husky-9.0.11.tgz#fc91df4c756050de41b3e478b2158b87c1e79af9" + integrity sha512-AB6lFlbwwyIqMdHYhwPe+kjOC3Oc5P3nThEoW/AaO2BX3vJDjWPFxYLxokUZOo6RNX20He3AaT8sESs9NJcmEw== + iconv-lite@0.6.3: version "0.6.3" resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.6.3.tgz#a52f80bf38da1952eb5c681790719871a1a72501"