Skip to content

Commit

Permalink
[Examples] Add ability to run and test examples
Browse files Browse the repository at this point in the history
Add a `lit.cfg.py` in the `examples` directory which sets up the lit config for
example Mojo files (notebooks not yet supported).  Add a wrapper script,
`run-examples.sh` which creates a build directory and invokes `lit` using this
configuration.

Go one step further and create a GitHub workflow that puts all of the pieces
together to download the latest stable Mojo compiler and test the examples using
the provided script.

The `scripts/run-examples.sh` is something that can be run both locally and in
CI.
  • Loading branch information
JoeLoser committed Mar 15, 2024
1 parent 59818e6 commit c064513
Show file tree
Hide file tree
Showing 4 changed files with 143 additions and 0 deletions.
53 changes: 53 additions & 0 deletions .github/workflows/examples.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
name: Test Examples

on:
pull_request:
workflow_dispatch:

jobs:
test-examples:
runs-on: ubuntu-latest
defaults:
run:
shell: bash
env:
DEBIAN_FRONTEND: noninteractive
TARGET_LLVM_VERSION: 17

steps:
- name: Checkout repo
uses: actions/checkout@v2

- name: "Get the modular installer, install mojo compiler"
run: |
echo "Downloading the Modular tool"
curl -s https://get.modular.com | sh -
echo "Downloading the latest Mojo compiler"
modular auth examples
modular install mojo
- name: Setup python
uses: actions/setup-python@0a5c61591373683505ea898e09a3ea4f39ef2b9c
with:
python-version: 3.12

- name: Install build tools
continue-on-error: true
run: |
wget https://apt.llvm.org/llvm.sh
chmod +x llvm.sh
sudo ./llvm.sh ${{env.TARGET_LLVM_VERSION}}
echo "/usr/lib/llvm/${{env.TARGET_LLVM_VERSION}}/bin" >> $GITHUB_PATH
which llvm
which clang++
which FileCheck
python3 -m pip install lit
- name: Run the examples
run: |
export MODULAR_HOME="/home/runner/.modular"
export PATH="/home/runner/.modular/pkg/packages.modular.com_mojo/bin:$PATH"
./scripts/run-examples.sh
7 changes: 7 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# Build directory
/build

# Python-related files
__pycache__/
*.py[cod]
*$py.class
56 changes: 56 additions & 0 deletions examples/lit.cfg.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
# ===----------------------------------------------------------------------=== #
# Copyright (c) 2024, Modular Inc. All rights reserved.
#
# Licensed under the Apache License v2.0 with LLVM Exceptions:
# https://llvm.org/LICENSE.txt
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ===----------------------------------------------------------------------=== #

from pathlib import Path

import lit.formats
import lit.llvm

config.test_format = lit.formats.ShTest(True)

# name: The name of this test suite.
config.name = "Mojo Public Examples"

# suffixes: A list of file extensions to treat as test files.
# TODO: Enable notebooks
config.suffixes = [".mojo", ".🔥"]

config.excludes = [
# No RUN: directive, just bare examples
"hello_interop.mojo",
"matmul.mojo"
]

# Have the examples run in the build directory.
# The `run-examples.sh` script creates the build directory.
build_root = Path.cwd().parent / "build"

# Execute the examples inside this part of the build
# directory to avoid polluting the source tree.
config.test_exec_root = build_root / "examples"

# test_source_root: The root path where tests are located.
config.test_source_root = Path.cwd()

# Substitute %mojo for just `mojo` itself.
config.substitutions.insert(0, ("%mojo", "mojo"))

# Pass through several environment variables
# to the underlying subprocesses that run the tests.
lit.llvm.initialize(lit_config, config)
lit.llvm.llvm_config.with_system_environment(
[
"MODULAR_HOME",
"PATH",
]
)
27 changes: 27 additions & 0 deletions scripts/run-examples.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
#!/usr/bin/env bash
# ===----------------------------------------------------------------------=== #
# Copyright (c) 2024, Modular Inc. All rights reserved.
#
# Licensed under the Apache License v2.0 with LLVM Exceptions:
# https://llvm.org/LICENSE.txt
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ===----------------------------------------------------------------------=== #

set -euo pipefail

SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
REPO_ROOT="${SCRIPT_DIR}"/../
EXAMPLES_DIR="${REPO_ROOT}"/examples

echo "Creating build directory"
BUILD_DIR="${REPO_ROOT}"/build
mkdir -p "${BUILD_DIR}"

# Change into the examples dir where lit.cfg.py is
# and then invoke lit to run the examples.
(cd "${EXAMPLES_DIR}" && lit -sv .)

0 comments on commit c064513

Please sign in to comment.