Skip to content

Commit

Permalink
Publish documentation website to gh-pages (#7)
Browse files Browse the repository at this point in the history
Summary:
This CL adds a Github Action to publish that publishes the [Docusaurus](https://docusaurus.io/) website that contains Scrut's documentation to the `gh-pages` branch.

Here the Github Page of my cloned repository that shows how the published website will look like: https://ukautz.github.io/scrut-tmp1/

The publishing is triggered on changes in the `main` branch and can be dispatched manually.

Pull Request resolved: #7

Reviewed By: abesto

Differential Revision: D52697773

Pulled By: ukautz

fbshipit-source-id: db90f568ba325cc89dac15b229e3e680f93cbc36
  • Loading branch information
ukautz authored and facebook-github-bot committed Jan 15, 2024
1 parent 8e04d6e commit bd7f308
Show file tree
Hide file tree
Showing 2 changed files with 53 additions and 2 deletions.
43 changes: 43 additions & 0 deletions .github/workflows/publish-documentation.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
name: Deploy to GitHub Pages

on:
push:
branches:
- main
workflow_dispatch: {}

permissions:
contents: write

jobs:
deploy:
name: Deploy to GitHub Pages
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 18
cache: yarn
cache-dependency-path: ./website/yarn.lock

- name: Install dependencies
run: cd website && yarn install --frozen-lockfile
- name: Build website
run: cd website && yarn build

# Popular action to deploy to GitHub Pages:
# Docs: https://github.com/peaceiris/actions-gh-pages#%EF%B8%8F-docusaurus
- name: Deploy to GitHub Pages
uses: peaceiris/actions-gh-pages@v3
with:
github_token: ${{ secrets.GITHUB_TOKEN }}
# Build output to publish to the `gh-pages` branch:
publish_dir: ./website/build
# The following lines assign commit authorship to the official
# GH-Actions bot for deploys to `gh-pages` branch:
# https://github.com/actions/checkout/issues/13#issuecomment-724415212
# The GH actions bot is used by default if you didn't specify the two fields.
# You can swap them out with your own user credentials.
user_name: github-actions[bot]
user_email: 41898282+github-actions[bot]@users.noreply.github.com
12 changes: 10 additions & 2 deletions website/docusaurus.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -10,18 +10,26 @@ const darkCodeTheme = require('prism-react-renderer/themes/dracula');

const {customFields} = require('./constants');

const { organizationName, baseUrl } =
"GITHUB_REPOSITORY" in process.env
? (() => {
const parts = process.env.GITHUB_REPOSITORY.split("/");
return { organizationName: parts[0], baseUrl: `/${parts[1]}/` };
})()
: { organizationName: "facebook", baseUrl: "/" };

// With JSDoc @type annotations, IDEs can provide config autocompletion
/** @type {import('@docusaurus/types').DocusaurusConfig} */
(module.exports = {
title: 'Scrut',
tagline: 'A CLI Testing Framework',
url: 'https://internalfb.com',
baseUrl: '/',
baseUrl,
onBrokenLinks: 'warn',
onBrokenMarkdownLinks: 'warn',
trailingSlash: true,
favicon: 'img/favicon.ico',
organizationName: 'facebook',
organizationName,
projectName: 'scrut', // TODO
customFields,

Expand Down

0 comments on commit bd7f308

Please sign in to comment.