Skip to content

Commit

Permalink
feat: Add Jekyll-based build for Vespa Search
Browse files Browse the repository at this point in the history
This commit introduces a new GitHub Action for building Jekyll-based
content compatible with Vespa Search. The changes include:

- Added the `jekyll-build-json/action.yml` file, which defines the
  inputs and configuration for the action.
- Added the `jekyll-build-json/Dockerfile` file, which sets up the
  build environment with the necessary dependencies.
- Added the `jekyll-build-json/Gemfile` file, which specifies the
  required Ruby gems for the Jekyll build.
- Added the `jekyll-build-json/entrypoint.sh` file, which is the
  entry point for the Docker container.
- Added the `docker-publish.yml` workflow file, which automates the
  build and publication of the Docker image for the action.

These changes enable the creation of Jekyll-based content that can be
easily consumed by the Vespa Search platform, improving the developer
experience and simplifying the integration process.
feat: Add Jekyll to Vespa feed workflow
  • Loading branch information
esolitos authored and gitbutler-client committed Aug 27, 2024
1 parent 9e19a6f commit 5ff5f8a
Show file tree
Hide file tree
Showing 7 changed files with 397 additions and 0 deletions.
92 changes: 92 additions & 0 deletions .github/workflows/docker-publish.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
name: Docker

# This workflow will generate container images for each of the Github Actions
# which are using a Dockerfile.

on:
push:
branches:
- "main"
- "feature-*"
tags:
- "v*"

jobs:
prepare:
# Finds all the Dockerfiles in the repository and sets the action names
# as output to reuse as matrix strategy in the build job
runs-on: ubuntu-latest

outputs:
matrix_json: ${{ steps.set-output.outputs.matrix_json }}

steps:
- uses: actions/checkout@v4

- name: Find Dockerfiles
id: set-output
run: |
# Find all Dockerfiles in the repository
paths_with_docker=$(find -type f -name 'Dockerfile' | sed 's|/Dockerfile||' | sed 's|./||')
# Transform the list of paths into a valid JSON array to be used as matrix strategy
action_names=$(echo $paths_with_docker | jq --raw-input --compact-output 'split(" ") | { "action-name": . }')
echo "Found Dockerfiles in the repository:"
echo "${action_names}"
echo "matrix_json=${action_names}" >> "${GITHUB_OUTPUT}"
build:
runs-on: ubuntu-latest

needs:
- prepare

permissions:
contents: read
packages: write

strategy:
matrix: ${{ fromJson(needs.prepare.outputs.matrix_json) }}

env:
REGISTRY: ghcr.io
IMAGE_NAME: ${{ github.repository }}/${{ matrix.action-name }}

steps:
- uses: actions/checkout@v4

- name: Log into registry ${{ env.REGISTRY }}
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: Set up QEMU
uses: docker/setup-qemu-action@v3

- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3

- name: Extract Docker metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}
tags: |
type=ref,event=pr
type=ref,event=branch
type=semver,pattern={{version}}
- name: Build and push Docker image
uses: docker/build-push-action@v6
with:
context: ${{ matrix.action-name }}
file: ${{ matrix.action-name }}/Dockerfile
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
# platforms: linux/amd64,linux/arm64 # Enable if we ever need to build for ARM
cache-from: type=gha
cache-to: type=gha,mode=max
25 changes: 25 additions & 0 deletions .github/workflows/jekyll-feed-to-vespa.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
---
name: Feed Jekyll posts to Vespa

on:
workflow_call:

defaults:
run:
# Specify to ensure "pipefail and errexit" are set.
# Ref: https://docs.github.com/en/actions/writing-workflows/workflow-syntax-for-github-actions#defaultsrunshell
shell: bash

jobs:
lint:
runs-on: ubuntu-latest

steps:
- uses: actions/checkout@v4

- name: Build with Jekyll
uses: vespa-engine/gh-actions/jekyll-build-json@feature-jekyll-build-json-action

- name: List JSON
run: |
find _site -type f -name '*.json' -exec jq empty {} \;
30 changes: 30 additions & 0 deletions jekyll-build-json/Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
ARG RUBY_VERSION=3.3
FROM ruby:$RUBY_VERSION-slim

RUN apt-get update \
&& apt-get install -y \
build-essential \
git \
locales

COPY Gemfile Gemfile

ENV NOKOGIRI_USE_SYSTEM_LIBRARIES=true

RUN gem env && \
bundle install --jobs 20 --retry 5

RUN \
echo "en_US UTF-8" > /etc/locale.gen && \
locale-gen en-US.UTF-8

ENV LANG=en_US.UTF-8
ENV LANGUAGE=en_US.UTF-8
ENV LC_ALL=en_US.UTF-8

COPY entrypoint.sh /entrypoint.sh

RUN mkdir -p /opt/jekyll/plugins
COPY vespa_index_generator.rb /opt/jekyll/plugins/vespa_index_generator.rb

ENTRYPOINT ["/entrypoint.sh"]
17 changes: 17 additions & 0 deletions jekyll-build-json/Gemfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
# Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
# frozen_string_literal: true

source "https://rubygems.org"

# Manage our dependency on the version of the github-pages gem here.
gem "github-pages", "= 232"

# Explicitly include this gem here.
# It is not directly included in the github-pages gem list of dependencies,
# even though it is included in the original GitHub Pages build infrastructure.
gem "jekyll-include-cache", "= 0.2.1"
gem "jekyll-octicons", "~> 14.2"
gem "minima", "~> 2.0"

# Work-around for webrick no longer included in Ruby 3.0 (https://github.com/jekyll/jekyll/issues/8523)
gem "webrick"
19 changes: 19 additions & 0 deletions jekyll-build-json/action.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
name: 'Build Jekyll for Vespa Search'
description: 'A simple GH Action for producing Jekyll build artifacts compatible with Vespa JSON'
author: 'Vespa.ai'
inputs:
source:
description: 'Directory where the source files reside (relative to the workspace).'
required: false
default: ./
destination:
description: 'Output directory of the build. Although it can be nested inside the source, it cannot be the same as the source directory (relative to the workspace).'
required: false
default: ./_site
config:
description: 'Jekyll configuration file path relative to the workspace root.'
required: false
default: ./_config.yml
runs:
using: 'docker'
image: 'docker://ghcr.io/vespa-engine/gh-actions/jekyll-build-json:feature-jekyll-build-json-action'
39 changes: 39 additions & 0 deletions jekyll-build-json/entrypoint.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
#!/bin/bash

set -e
set -o pipefail
set -o nounset

SOURCE_DIRECTORY=${GITHUB_WORKSPACE}/${INPUT_SOURCE}
DESTINATION_DIRECTORY=${GITHUB_WORKSPACE}/${INPUT_DESTINATION}
JEKYLL_CONFIG_FILE=${GITHUB_WORKSPACE}/${INPUT_CONFIG}

# Set environment variables required by supported plugins
export JEKYLL_ENV="production"
export JEKYLL_GITHUB_TOKEN=$INPUT_TOKEN
export JEKYLL_BUILD_REVISION=$INPUT_BUILD_REVISION

{ cd "$BUNDLE_APP_CONFIG" || { echo "::error::pages gem not found"; exit 1; }; }

if [[ "${RUNNER_DEBUG:-}" == "1" ]]; then
gem env
bundle env
fi

# Run the command, capturing the output
build_output="$(bundle exec jekyll build -p /opt/jekyll/plugins --config="${JEKYLL_CONFIG_FILE}" --source "${SOURCE_DIRECTORY}" --destination "${DESTINATION_DIRECTORY}")"

# Capture the exit code
exit_code=$?

if [ $exit_code -ne 0 ]; then
# Remove the newlines from the build_output as annotation not support multiline
error=$(echo "$build_output" | tr '\n' ' ' | tr -s ' ')
echo "::error::$error"
else
# Display the build_output directly
echo "$build_output"
fi

# Exit with the captured exit code
exit $exit_code
Loading

0 comments on commit 5ff5f8a

Please sign in to comment.