generated from duckdb/extension-template
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit c323d7b
Showing
21 changed files
with
1,045 additions
and
0 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
# | ||
# This workflow runs (some of) the client test for the DuckDB extension. These should only be used when necessary, writing | ||
# regular SQL tests is generally preferable. Feel free to remove this workflow for your extension. | ||
# | ||
|
||
name: Client specific tests | ||
on: [push, pull_request, repository_dispatch] | ||
|
||
concurrency: | ||
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.head_ref || '' }}-${{ github.base_ref || '' }}-${{ github.ref != 'refs/heads/main' || github.sha }} | ||
cancel-in-progress: true | ||
|
||
jobs: | ||
client-tests: | ||
name: Client Tests | ||
uses: duckdb/duckdb/.github/workflows/_extension_client_tests.yml@v0.9.2 | ||
with: | ||
duckdb_version: v0.9.2 |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,177 @@ | ||
# | ||
# NOTE: this workflow is for testing the extension template itself, | ||
# this workflow will be removed when scripts/bootstrap-template.py is run | ||
# | ||
name: Extension Template | ||
on: [push, pull_request,repository_dispatch] | ||
concurrency: | ||
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.head_ref || '' }}-${{ github.base_ref || '' }}-${{ github.ref != 'refs/heads/main' || github.sha }} | ||
cancel-in-progress: true | ||
|
||
jobs: | ||
linux: | ||
name: Linux | ||
if: ${{ vars.RUN_RENAME_TEST == 'true' }} | ||
runs-on: ubuntu-latest | ||
container: ubuntu:18.04 | ||
strategy: | ||
matrix: | ||
# Add commits/tags to build against other DuckDB versions | ||
duckdb_version: [ '<submodule_version>' ] | ||
env: | ||
VCPKG_TOOLCHAIN_PATH: ${{ github.workspace }}/vcpkg/scripts/buildsystems/vcpkg.cmake | ||
VCPKG_TARGET_TRIPLET: 'x64-linux' | ||
GEN: ninja | ||
defaults: | ||
run: | ||
shell: bash | ||
|
||
steps: | ||
- name: Install required ubuntu packages | ||
run: | | ||
apt-get update -y -qq | ||
apt-get install -y -qq software-properties-common | ||
add-apt-repository ppa:git-core/ppa | ||
apt-get update -y -qq | ||
apt-get install -y -qq ninja-build make gcc-multilib g++-multilib libssl-dev wget openjdk-8-jdk zip maven unixodbc-dev libc6-dev-i386 lib32readline6-dev libssl-dev libcurl4-gnutls-dev libexpat1-dev gettext unzip build-essential checkinstall libffi-dev curl libz-dev openssh-client | ||
- name: Install Git 2.18.5 | ||
run: | | ||
wget https://github.com/git/git/archive/refs/tags/v2.18.5.tar.gz | ||
tar xvf v2.18.5.tar.gz | ||
cd git-2.18.5 | ||
make | ||
make prefix=/usr install | ||
git --version | ||
- uses: actions/checkout@v3 | ||
with: | ||
fetch-depth: 0 | ||
submodules: 'true' | ||
|
||
- name: Checkout DuckDB to version | ||
if: ${{ matrix.duckdb_version != '<submodule_version>'}} | ||
run: | | ||
cd duckdb | ||
git checkout ${{ matrix.duckdb_version }} | ||
- uses: ./duckdb/.github/actions/ubuntu_18_setup | ||
|
||
- name: Setup vcpkg | ||
uses: lukka/run-vcpkg@v11.1 | ||
with: | ||
vcpkgGitCommitId: a42af01b72c28a8e1d7b48107b33e4f286a55ef6 | ||
|
||
- name: Rename extension | ||
run: | | ||
python3 scripts/bootstrap-template.py ext_1_a_123b_b11 | ||
- name: Build | ||
run: | | ||
make | ||
- name: Test | ||
run: | | ||
make test | ||
macos: | ||
name: MacOS | ||
if: ${{ vars.RUN_RENAME_TEST == 'true' }} | ||
runs-on: macos-latest | ||
strategy: | ||
matrix: | ||
# Add commits/tags to build against other DuckDB versions | ||
duckdb_version: [ '<submodule_version>'] | ||
env: | ||
VCPKG_TOOLCHAIN_PATH: ${{ github.workspace }}/vcpkg/scripts/buildsystems/vcpkg.cmake | ||
VCPKG_TARGET_TRIPLET: 'x64-osx' | ||
OSX_BUILD_ARCH: 'x86_64' | ||
GEN: ninja | ||
defaults: | ||
run: | ||
shell: bash | ||
|
||
steps: | ||
- uses: actions/checkout@v3 | ||
with: | ||
fetch-depth: 0 | ||
submodules: 'true' | ||
|
||
- name: Install Ninja | ||
run: brew install ninja | ||
|
||
- uses: actions/setup-python@v2 | ||
with: | ||
python-version: '3.7' | ||
|
||
- name: Checkout DuckDB to version | ||
if: ${{ matrix.duckdb_version != '<submodule_version>'}} | ||
run: | | ||
cd duckdb | ||
git checkout ${{ matrix.duckdb_version }} | ||
- name: Setup vcpkg | ||
uses: lukka/run-vcpkg@v11.1 | ||
with: | ||
vcpkgGitCommitId: a42af01b72c28a8e1d7b48107b33e4f286a55ef6 | ||
|
||
- name: Rename extension | ||
run: | | ||
python scripts/bootstrap-template.py ext_1_a_123b_b11 | ||
- name: Build | ||
run: | | ||
make | ||
- name: Test | ||
run: | | ||
make test | ||
windows: | ||
name: Windows | ||
if: ${{ vars.RUN_RENAME_TEST == 'true' }} | ||
runs-on: windows-latest | ||
strategy: | ||
matrix: | ||
# Add commits/tags to build against other DuckDB versions | ||
duckdb_version: [ '<submodule_version>' ] | ||
env: | ||
VCPKG_TOOLCHAIN_PATH: ${{ github.workspace }}/vcpkg/scripts/buildsystems/vcpkg.cmake | ||
VCPKG_TARGET_TRIPLET: 'x64-windows-static-md' | ||
defaults: | ||
run: | ||
shell: bash | ||
|
||
steps: | ||
- uses: actions/checkout@v3 | ||
with: | ||
fetch-depth: 0 | ||
submodules: 'true' | ||
|
||
- uses: actions/setup-python@v2 | ||
with: | ||
python-version: '3.7' | ||
|
||
- name: Checkout DuckDB to version | ||
# Add commits/tags to build against other DuckDB versions | ||
if: ${{ matrix.duckdb_version != '<submodule_version>'}} | ||
run: | | ||
cd duckdb | ||
git checkout ${{ matrix.duckdb_version }} | ||
- name: Setup vcpkg | ||
uses: lukka/run-vcpkg@v11.1 | ||
with: | ||
vcpkgGitCommitId: a42af01b72c28a8e1d7b48107b33e4f286a55ef6 | ||
|
||
- name: Rename extension | ||
run: | | ||
python scripts/bootstrap-template.py ext_1_a_123b_b11 | ||
- name: Build | ||
run: | | ||
make | ||
- name: Test extension | ||
run: | | ||
build/release/test/Release/unittest.exe |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
# | ||
# This workflow calls the main distribution pipeline from DuckDB to build, test and (optionally) release the extension | ||
# | ||
name: Main Extension Distribution Pipeline | ||
on: | ||
push: | ||
pull_request: | ||
workflow_dispatch: | ||
|
||
concurrency: | ||
group: ${{ github.workflow }}-${{ github.ref }}-${{ github.head_ref || '' }}-${{ github.base_ref || '' }}-${{ github.ref != 'refs/heads/main' || github.sha }} | ||
cancel-in-progress: true | ||
|
||
jobs: | ||
duckdb-stable-build: | ||
name: Build extension binaries | ||
uses: duckdb/duckdb/.github/workflows/_extension_distribution.yml@v0.9.2 | ||
with: | ||
vcpkg_commit: a42af01b72c28a8e1d7b48107b33e4f286a55ef6 | ||
duckdb_version: v0.9.2 | ||
extension_name: quack | ||
|
||
duckdb-stable-deploy: | ||
name: Deploy extension binaries | ||
needs: duckdb-stable-build | ||
uses: ./.github/workflows/_extension_deploy.yml | ||
secrets: inherit | ||
with: | ||
duckdb_version: v0.9.2 | ||
extension_name: quack | ||
deploy_latest: ${{ startsWith(github.ref, 'refs/tags/v') || github.ref == 'refs/heads/main' }} | ||
deploy_versioned: ${{ startsWith(github.ref, 'refs/tags/v') || github.ref == 'refs/heads/main' }} |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,121 @@ | ||
# | ||
# Reusable workflow that deploys the artifacts produced by github.com/duckdb/duckdb/.github/workflows/_extension_distribution.yml | ||
# | ||
# note: this workflow needs to be located in the extension repository, as it requires secrets to be passed to the | ||
# deploy script. However, it should generally not be necessary to modify this workflow in your extension repository, as | ||
# this workflow can be configured to use a custom deploy script. | ||
|
||
|
||
name: Extension Deployment | ||
on: | ||
workflow_call: | ||
inputs: | ||
# The name of the extension | ||
extension_name: | ||
required: true | ||
type: string | ||
# DuckDB version to build against | ||
duckdb_version: | ||
required: true | ||
type: string | ||
# ';' separated list of architectures to exclude, for example: 'linux_amd64;osx_arm64' | ||
exclude_archs: | ||
required: false | ||
type: string | ||
default: "" | ||
# Whether to upload this deployment as the latest. This may overwrite a previous deployment. | ||
deploy_latest: | ||
required: false | ||
type: boolean | ||
default: false | ||
# Whether to upload this deployment under a versioned path. These will not be deleted automatically | ||
deploy_versioned: | ||
required: false | ||
type: boolean | ||
default: false | ||
# Postfix added to artifact names. Can be used to guarantee unique names when this workflow is called multiple times | ||
artifact_postfix: | ||
required: false | ||
type: string | ||
default: "" | ||
# Override the default deploy script with a custom script | ||
deploy_script: | ||
required: false | ||
type: string | ||
default: "./scripts/extension-upload.sh" | ||
# Override the default matrix parse script with a custom script | ||
matrix_parse_script: | ||
required: false | ||
type: string | ||
default: "./duckdb/scripts/modify_distribution_matrix.py" | ||
|
||
jobs: | ||
generate_matrix: | ||
name: Generate matrix | ||
runs-on: ubuntu-latest | ||
outputs: | ||
deploy_matrix: ${{ steps.parse-matrices.outputs.deploy_matrix }} | ||
steps: | ||
- uses: actions/checkout@v3 | ||
with: | ||
fetch-depth: 0 | ||
submodules: 'true' | ||
|
||
- name: Checkout DuckDB to version | ||
run: | | ||
cd duckdb | ||
git checkout ${{ inputs.duckdb_version }} | ||
- id: parse-matrices | ||
run: | | ||
python3 ${{ inputs.matrix_parse_script }} --input ./duckdb/.github/config/distribution_matrix.json --deploy_matrix --output deploy_matrix.json --exclude "${{ inputs.exclude_archs }}" --pretty | ||
deploy_matrix="`cat deploy_matrix.json`" | ||
echo deploy_matrix=$deploy_matrix >> $GITHUB_OUTPUT | ||
echo `cat $GITHUB_OUTPUT` | ||
deploy: | ||
name: Deploy | ||
runs-on: ubuntu-latest | ||
needs: generate_matrix | ||
if: ${{ needs.generate_matrix.outputs.deploy_matrix != '{}' && needs.generate_matrix.outputs.deploy_matrix != '' }} | ||
strategy: | ||
matrix: ${{fromJson(needs.generate_matrix.outputs.deploy_matrix)}} | ||
|
||
steps: | ||
- uses: actions/checkout@v3 | ||
with: | ||
fetch-depth: 0 | ||
submodules: 'true' | ||
|
||
- name: Checkout DuckDB to version | ||
run: | | ||
cd duckdb | ||
git checkout ${{ inputs.duckdb_version }} | ||
- uses: actions/download-artifact@v2 | ||
with: | ||
name: ${{ inputs.extension_name }}-${{ inputs.duckdb_version }}-extension-${{matrix.duckdb_arch}}${{inputs.artifact_postfix}} | ||
path: | | ||
/tmp/extension | ||
- name: Deploy | ||
shell: bash | ||
env: | ||
AWS_ACCESS_KEY_ID: ${{ secrets.S3_DUCKDB_ORG_DEPLOY_ID }} | ||
AWS_SECRET_ACCESS_KEY: ${{ secrets.S3_DUCKDB_ORG_DEPLOY_KEY }} | ||
AWS_DEFAULT_REGION: ${{ secrets.S3_DUCKDB_ORG_REGION }} | ||
BUCKET_NAME: ${{ secrets.S3_DUCKDB_ORG_BUCKET }} | ||
DUCKDB_EXTENSION_SIGNING_PK: ${{ secrets.S3_DUCKDB_ORG_EXTENSION_SIGNING_PK }} | ||
run: | | ||
pwd | ||
python3 -m pip install pip awscli | ||
git config --global --add safe.directory '*' | ||
cd duckdb | ||
git fetch --tags | ||
export DUCKDB_VERSION=`git tag --points-at HEAD` | ||
export DUCKDB_VERSION=${DUCKDB_VERSION:=`git log -1 --format=%h`} | ||
cd .. | ||
git fetch --tags | ||
export EXT_VERSION=`git tag --points-at HEAD` | ||
export EXT_VERSION=${EXT_VERSION:=`git log -1 --format=%h`} | ||
${{ inputs.deploy_script }} ${{ inputs.extension_name }} $EXT_VERSION $DUCKDB_VERSION ${{ matrix.duckdb_arch }} $BUCKET_NAME ${{inputs.deploy_latest || 'true' && 'false'}} ${{inputs.deploy_versioned || 'true' && 'false'}} |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
build | ||
.idea | ||
cmake-build-debug | ||
duckdb_unittest_tempdir/ | ||
.DS_Store | ||
testext | ||
test/python/__pycache__/ | ||
.Rhistory |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
[submodule "duckdb"] | ||
path = duckdb | ||
url = https://github.com/duckdb/duckdb | ||
branch = main |
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
cmake_minimum_required(VERSION 2.8.12) | ||
|
||
# Set extension name here | ||
set(TARGET_NAME quack) | ||
|
||
# DuckDB's extension distribution supports vcpkg. As such, dependencies can be added in ./vcpkg.json and then | ||
# used in cmake with find_package. Feel free to remove or replace with other dependencies. | ||
# Note that it should also be removed from vcpkg.json to prevent needlessly installing it.. | ||
find_package(OpenSSL REQUIRED) | ||
|
||
set(EXTENSION_NAME ${TARGET_NAME}_extension) | ||
set(LOADABLE_EXTENSION_NAME ${TARGET_NAME}_loadable_extension) | ||
|
||
project(${TARGET_NAME}) | ||
include_directories(src/include) | ||
|
||
set(EXTENSION_SOURCES src/quack_extension.cpp) | ||
|
||
build_static_extension(${TARGET_NAME} ${EXTENSION_SOURCES}) | ||
build_loadable_extension(${TARGET_NAME} " " ${EXTENSION_SOURCES}) | ||
|
||
# Link OpenSSL in both the static library as the loadable extension | ||
target_link_libraries(${EXTENSION_NAME} OpenSSL::SSL OpenSSL::Crypto) | ||
target_link_libraries(${LOADABLE_EXTENSION_NAME} OpenSSL::SSL OpenSSL::Crypto) | ||
|
||
install( | ||
TARGETS ${EXTENSION_NAME} | ||
EXPORT "${DUCKDB_EXPORT_SET}" | ||
LIBRARY DESTINATION "${INSTALL_LIB_DIR}" | ||
ARCHIVE DESTINATION "${INSTALL_LIB_DIR}") |
Oops, something went wrong.