Skip to content

Commit

Permalink
[CI] Implement C++ CI scripts using python
Browse files Browse the repository at this point in the history
Signed-off-by: LiangliangSui <[email protected]>
  • Loading branch information
LiangliangSui committed Jan 4, 2024
1 parent 204fd97 commit 5cc874c
Show file tree
Hide file tree
Showing 2 changed files with 106 additions and 4 deletions.
11 changes: 7 additions & 4 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -145,11 +145,14 @@ jobs:
uses: actions/setup-python@v2
with:
python-version: 3.8
- name: Install bazel
run: ./ci/run_ci.sh install_bazel
- name: Install Bazel
run: |
pip install wget
pip install psutil
pip install pyarrow==14.0.0
python ./ci/run_ci.py --install-bazel
- name: Run C++ CI with Bazel
run: ./ci/run_ci.sh cpp

run: python ./ci/run_ci.py -i cpp
python:
name: Python CI
# Fix python 3.6 install issue, see
Expand Down
99 changes: 99 additions & 0 deletions ci/run_ci.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# 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.


import argparse
import subprocess
import platform
import psutil
import wget
import os


def _exec_cmd(cmd: list, stdout=None):
print(f"run command: {cmd}")
ret = subprocess.run(cmd, stdout=stdout)
assert ret.returncode == 0
return ret


def _get_os_name_lower():
return platform.system().lower()


def _install_bazel():
os_name = _get_os_name_lower()
if os_name == "windows":
# TODO: Implement Windows download bazel.
bazel_cmd = "./bazel"
else:
URL = f"https://github.com/bazelbuild/bazel/releases/download/6.3.2/bazel-6.3.2-installer-{os_name}-x86_64.sh"
local_name = "installer.sh"
wget.download(URL, local_name)
os.chmod(local_name, 0o777)
_exec_cmd([f"./{local_name}", "--user"])
bazel_cmd = "bazel"

# bazel install status check
_exec_cmd([bazel_cmd, "--version"])

# default is byte
total_mem = psutil.virtual_memory().total
limit_jobs = int(total_mem / 1024 / 1024 / 1024 / 3)
with open(".bazelrc", "a") as file:
file.write(f"\nbuild --jobs={limit_jobs}")


def _run_cpp():
bazel_cmd = "./bazel" if _get_os_name_lower() == "windows" else "bazel"

# run test
query_result = _exec_cmd([bazel_cmd, "query", "//..."], stdout=subprocess.PIPE)
test_cmd = [bazel_cmd, "test"] + str(query_result.stdout, "utf-8").splitlines()
_exec_cmd(test_cmd)


def _run(item):
if item == "cpp":
_run_cpp()
else:
# TODO: Implement other CI Tests.
pass


def _parse_args():
parser = argparse.ArgumentParser()
choices = ["java", "cpp"]
parser.add_argument(
"-i", "--item", choices=choices, help="Specify an item that needs to be run"
)
parser.add_argument(
"--install-bazel",
"-install_bazel",
action="store_true",
help="Install bazel on the current machine",
)
return parser.parse_args()


if __name__ == "__main__":
args = _parse_args()

if args.item:
_run(args.item)
elif args.install_bazel:
_install_bazel()

0 comments on commit 5cc874c

Please sign in to comment.