Skip to content

Build and deploy demo #1504

Build and deploy demo

Build and deploy demo #1504

Workflow file for this run

name: Build and deploy demo
on:
workflow_dispatch:
schedule:
- cron: '0 0 * * *'
jobs:
scheduled:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
name: Check out repo
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: "3.12"
cache: pip
cache-dependency-path: setup.py
- name: Install Python dependencies
run: |
python -m pip install --upgrade pip
pip install sqlite-utils>=3.1
sqlite-utils --version
pip install -e .
pip install datasette
pip install bs4
- name: Create auth.json
env:
GITHUB_ACCESS_TOKEN: ${{ secrets.GH_TOKEN }}
run: |
echo "{\"github_personal_token\": \"$GITHUB_ACCESS_TOKEN\"}" > auth.json
- name: Fetch previous copy of database
if: |-
!contains(github.event.head_commit.message, 'REFRESH_DB')
run: |-
# So we can keep track of when we first saw each dependent repo
wget https://github-to-sqlite.dogsheep.net/github.db
- name: Fetch the repos
run: |-
github-to-sqlite repos github.db dogsheep
sqlite-utils tables --counts github.db
- name: Fetch releases, commits, issues, contributors
run: |-
sqlite-utils github.db "select full_name from repos where owner = 53015001 union select 'simonw/datasette' as full_name union select 'simonw/sqlite-utils' as full_name" \
--csv --no-headers | while read repo;
do github-to-sqlite releases \
github.db $(echo $repo | tr -d '\r');
sleep 10;
github-to-sqlite commits \
github.db $(echo $repo | tr -d '\r');
sleep 10;
github-to-sqlite tags \
github.db $(echo $repo | tr -d '\r');
sleep 10;
github-to-sqlite contributors \
github.db $(echo $repo | tr -d '\r');
sleep 10;
github-to-sqlite issues \
github.db $(echo $repo | tr -d '\r');
sleep 10;
github-to-sqlite pull-requests \
github.db $(echo $repo | tr -d '\r');
sleep 10;
github-to-sqlite issue-comments \
github.db $(echo $repo | tr -d '\r');
sleep 10;
github-to-sqlite stargazers \
github.db $(echo $repo | tr -d '\r');
sleep 10;
github-to-sqlite workflows \
github.db $(echo $repo | tr -d '\r');
sleep 10;
done;
# Scrape dependents
github-to-sqlite scrape-dependents github.db simonw/datasette simonw/sqlite-utils -v
sqlite-utils tables --counts github.db
# Delete email addresses from raw_authors
sqlite-utils github.db "update raw_authors set email = ''"
# Fetch emojis
github-to-sqlite emojis github.db --fetch
# Rebuild FTS tables
sqlite-utils rebuild-fts github.db
# Populate _analyze_tables_ table
sqlite-utils analyze-tables github.db --save
- uses: actions/upload-artifact@v3
with:
path: github.db
- name: Set up Cloud Run
uses: google-github-actions/setup-gcloud@v0
with:
version: '318.0.0'
service_account_email: ${{ secrets.GCP_SA_EMAIL }}
service_account_key: ${{ secrets.GCP_SA_KEY }}
- name: Deploy to Cloud Run
run: |-
gcloud config set run/region us-central1
gcloud config set project datasette-222320
datasette publish cloudrun github.db \
-m demo-metadata.json \
--service github-to-sqlite \
--install=datasette-search-all>=0.3 \
--install=datasette-render-markdown>=1.1.2 \
--install=datasette-pretty-json>=0.2.2 \
--install=datasette-json-html \
--install=datasette-vega \
--install=datasette-render-images \
--install=datasette-graphql \
--install=datasette-atom