Weekly CSV File Generation and Release #150
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Weekly CSV File Generation and Release | |
on: | |
push: | |
branches: | |
- main | |
schedule: | |
- cron: '0 10 * * 1' # Every Monday at 10AM | |
jobs: | |
generate_and_release_csv: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v3 | |
- name: Install Poetry | |
uses: snok/install-poetry@v1 | |
with: | |
version: 1.5.1 | |
virtualenvs-create: true | |
virtualenvs-in-project: true | |
- name: Set up Python | |
uses: actions/setup-python@v4 | |
with: | |
python-version: "3.9" | |
cache: "poetry" | |
- name: Set up Poetry Path | |
run: echo "$HOME/.local/bin" >> $GITHUB_PATH | |
- name: Install dependencies | |
run: poetry install --no-interaction | |
- name: Create CSV | |
run: poetry run python -m ocw_oer_export.cli --create_csv --output_path="./private/output/ocw_oer_export.csv" | |
- name: Slack Notification | |
if: failure() | |
uses: rtCamp/action-slack-notify@v2 | |
env: | |
SLACK_WEBHOOK: ${{ secrets.SLACK_WEBHOOK }} | |
SLACK_COLOR: '#870000' | |
SLACK_MESSAGE: 'Error in creating CSV file. Please refer to the Actions URL to see logs.' | |
SLACK_MSG_AUTHOR: 'mitodl/ocw_oer_export' | |
- name: Generate Version Number | |
run: | | |
git fetch --tags | |
LATEST_TAG=$(git tag | grep -E '^v[0-9]+\.[0-9]+\.[0-9]+-csv$' | sort -V | tail -n1) | |
# If no tags exist, start with v1.0.0-csv | |
if [ -z "$LATEST_TAG" ] | |
then | |
LATEST_TAG="v1.0.0-csv" | |
fi | |
BASE_TAG=${LATEST_TAG#v} # Remove the leading 'v' | |
BASE_TAG=${BASE_TAG%-csv} # Remove the trailing '-csv' | |
IFS='.' read -a TAG_PARTS <<< "$BASE_TAG" | |
TAG_PARTS[2]=$((TAG_PARTS[2]+1)) # Increment the patch number | |
NEW_TAG="v${TAG_PARTS[0]}.${TAG_PARTS[1]}.${TAG_PARTS[2]}-csv" | |
echo "TAG_NAME=$NEW_TAG" >> $GITHUB_ENV | |
- name: Format Release Date for Release Title | |
run: | | |
DaySuffix() { | |
case `date +%d` in | |
1|21|31) echo "st";; | |
2|22) echo "nd";; | |
3|23) echo "rd";; | |
*) echo "th";; | |
esac | |
} | |
TZ="US/Eastern" | |
TODAY=$(date +"%A, %B %-d"$(DaySuffix)", %Y") | |
echo "RELEASE_TITLE=${TODAY}" >> $GITHUB_ENV | |
- name: Create Release with Timestamp | |
run: | |
| | |
echo "Creating release: $TAG_NAME" | |
gh release create "${{ env.TAG_NAME }}" ./private/output/ocw_oer_export.csv -p -t "${{ env.RELEASE_TITLE }}" -n "This release was created for CSV weekly output. Please get the CSV file from the Assets listed below." --target $GITHUB_SHA | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- name: Update 'Latest' Release | |
run: | | |
LATEST_RELEASE_NAME="latest" | |
if gh release view $LATEST_RELEASE_NAME | |
then | |
gh release delete $LATEST_RELEASE_NAME | |
if git rev-parse $LATEST_RELEASE_NAME | |
then | |
git tag -d $LATEST_RELEASE_NAME | |
git push --delete origin $LATEST_RELEASE_NAME | |
fi | |
fi | |
gh release create $LATEST_RELEASE_NAME ./private/output/ocw_oer_export.csv -t "Latest Release" -n "This release was created for CSV weekly output. This release contains the most recent CSV. Please get the CSV file from the Assets listed below." --latest --target $GITHUB_SHA | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |