-
Notifications
You must be signed in to change notification settings - Fork 16
67 lines (57 loc) · 2.17 KB
/
ci.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
name: CI
on: [push, pull_request]
jobs:
tests:
runs-on: ubuntu-latest
services:
mysql:
image: mysql:8.3
env:
MYSQL_ROOT_PASSWORD: root
MYSQL_DATABASE: ccdb_test
ports:
- 3306:3306
options: --health-cmd="mysqladmin ping" --health-interval=10s --health-timeout=5s --health-retries=5
steps:
- uses: actions/checkout@v2
- name: Set up Python
uses: actions/setup-python@v2
with:
python-version: '3.8' # Choose the Python version as per your requirement
- name: Install Python dependencies
run: |
pip install -r python/requirements.txt
ls
- name: Set up environment
run: |
sudo apt-get update
sudo apt-get install build-essential cmake mysql-client
# Add any other dependencies for C++ here
# For example, if you use CMake:
# - name: Install CMake
# run: sudo apt-get install cmake
- name: Create MySQL Database
run: |
mysql -h 127.0.0.1 -u root --password=root -e 'CREATE USER `ccdb_user`@`localhost`;'
mysql -h 127.0.0.1 -u root --password=root -e 'CREATE SCHEMA IF NOT EXISTS `ccdb_test`;'
mysql -h 127.0.0.1 -u root --password=root -e 'GRANT ALL PRIVILEGES ON ccdb_test.* TO `ccdb_user`@`localhost`;'
mysql -h 127.0.0.1 -u root --password=root ccdb_test < sql/ccdb.mysql.sql
- name: Run tests
env:
MYSQL_HOST: 127.0.0.1
MYSQL_USER: root
MYSQL_PASSWORD: root
MYSQL_DB: testdb
CCDB_TEST_MYSQL_CONNECTION: mysql://ccdb_user@localhost/ccdb_test
CCDB_TEST_SQLITE_CONNECTION: sqlite:///sql/ccdb.sqlite
run: |
# Command to run your Python tests
# For example, if you use pytest:
#python -m pytest
source environment.bash
chmod +x ./bin/test_ccdb_python3
./bin/test_ccdb_python3
# Command to compile and run your C++ tests
# Adjust these commands according to your build system and test framework
#g++ -o test_program source_code.cpp
#./test_program