Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add CB CI tests #572

Merged
merged 48 commits into from
Jul 10, 2024
Merged
Changes from 6 commits
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
7814fce
Add workflow
as-suvorov Jul 2, 2024
d0104e4
Add win and mac
as-suvorov Jul 2, 2024
e9acf25
Fix mac package link
as-suvorov Jul 2, 2024
7b8f41d
Remote timeout for mac
as-suvorov Jul 2, 2024
2282497
Try bash shell for win
as-suvorov Jul 2, 2024
a460880
Set PATH for win
as-suvorov Jul 2, 2024
cb04caa
Add tests
as-suvorov Jul 2, 2024
f1b3cb8
Increase timeout
as-suvorov Jul 2, 2024
b5b8db5
Increase timeout
as-suvorov Jul 2, 2024
43f89a2
Add tests for win and mac
as-suvorov Jul 3, 2024
8ea9f40
Fix win tests
as-suvorov Jul 3, 2024
f22f711
Increate timeout
as-suvorov Jul 3, 2024
ca4787c
Remove timeout
as-suvorov Jul 3, 2024
b4b18e9
add python tests
as-suvorov Jul 3, 2024
9999349
Skip tests
as-suvorov Jul 3, 2024
4adf912
Unskip win
as-suvorov Jul 3, 2024
5594b04
Update gitignore
as-suvorov Jul 3, 2024
267b240
Merge remote-tracking branch 'upstream/master' into as/add_cb_ci_tests
as-suvorov Jul 3, 2024
cdddb38
Print results
as-suvorov Jul 3, 2024
66d9e7d
Skip random sampling test
as-suvorov Jul 4, 2024
de9503f
Enable continuous batching in python package
as-suvorov Jul 4, 2024
ce817b4
Fix wheel install
as-suvorov Jul 4, 2024
ee1fa38
Install to pygenai
as-suvorov Jul 4, 2024
176bc22
add win mac tests
as-suvorov Jul 4, 2024
8bb3939
Skip mac tests
as-suvorov Jul 4, 2024
452acbd
Skip tests
as-suvorov Jul 4, 2024
81642d5
Skip preemtion tests for win mac
as-suvorov Jul 4, 2024
16b4a15
Add reason
as-suvorov Jul 4, 2024
7356b2f
Cleanup workflow
as-suvorov Jul 5, 2024
0e787d1
Merge remote-tracking branch 'upstream/master' into as/add_cb_ci_tests
as-suvorov Jul 5, 2024
0493d04
Add max_new_tokens to GenerationConfig tests
as-suvorov Jul 5, 2024
d4d60fc
Fix tests
as-suvorov Jul 5, 2024
7de36c7
Move workflows
as-suvorov Jul 5, 2024
7c297e7
Add mac package url
as-suvorov Jul 5, 2024
8cde1aa
Increase timeout
as-suvorov Jul 5, 2024
e0e7aee
Trigger tests
as-suvorov Jul 5, 2024
b1ce299
Merge branch 'master' into as/add_cb_ci_tests
as-suvorov Jul 8, 2024
3404184
Fix test
as-suvorov Jul 8, 2024
459005c
Fix python tests
as-suvorov Jul 8, 2024
7817de4
Skip preemption test
as-suvorov Jul 9, 2024
fa27c8e
Merge branch 'master' into as/add_cb_ci_tests
as-suvorov Jul 9, 2024
f72e99d
Merge remote-tracking branch 'upstream/master' into as/add_cb_ci_tests
as-suvorov Jul 9, 2024
13eee61
Merge remote-tracking branch 'origin/as/add_cb_ci_tests' into as/add_…
as-suvorov Jul 9, 2024
471e14b
Align with master
as-suvorov Jul 9, 2024
c090dc6
Add target_compile_features cxx_std_20
as-suvorov Jul 9, 2024
bc17fc9
Add target back
as-suvorov Jul 9, 2024
60f45c8
Remove c++20 from cb samples
as-suvorov Jul 9, 2024
6a95fab
Remove c++ 20 from benchamrk sample
as-suvorov Jul 9, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
125 changes: 125 additions & 0 deletions .github/workflows/continuous_batching_cpp.yml
Wovchena marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,125 @@
on:
pull_request:
paths:
- .github/workflows/continuous_batching_cpp.yml
- src/**
- samples/**
- thirdparty/openvino_tokenizers
- "!**.md"
permissions: read-all # Required by https://github.com/ossf/scorecard/blob/e23b8ad91fd6a64a0a971ca4fc0a4d1650725615/docs/checks.md#token-permissions
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true

env:
l_ov_link: https://storage.openvinotoolkit.org/repositories/openvino/packages/nightly/2024.3.0-15805-6138d624dc1/l_openvino_toolkit_ubuntu20_2024.3.0.dev20240626_x86_64.tgz
w_ov_link: https://storage.openvinotoolkit.org/repositories/openvino/packages/nightly/2024.3.0-15805-6138d624dc1/w_openvino_toolkit_windows_2024.3.0.dev20240626_x86_64.zip
m_ov_link: https://storage.openvinotoolkit.org/repositories/openvino/packages/nightly/2024.3.0-15805-6138d624dc1/m_openvino_toolkit_macos_12_6_2024.3.0.dev20240626_x86_64.tgz
jobs:
cpp-accuracy-sample-ubuntu:
runs-on: ubuntu-20.04-8-cores
steps:
- uses: actions/checkout@v4
with:
submodules: recursive
- uses: actions/setup-python@v4
with:
python-version: 3.8
- name: Install OpenVINO
run: |
mkdir ./ov/
curl ${{ env.l_ov_link }} | tar --directory ./ov/ --strip-components 1 -xz
sudo ./ov/install_dependencies/install_openvino_dependencies.sh
- name: Download, convert and build
run: |
source ./ov/setupvars.sh
python -m pip install --upgrade-strategy eager -r ./samples/requirements.txt --pre --extra-index-url https://storage.openvinotoolkit.org/simple/wheels/nightly
python -m pip install ./thirdparty/openvino_tokenizers/[transformers] --pre --extra-index-url https://storage.openvinotoolkit.org/simple/wheels/nightly
optimum-cli export openvino --trust-remote-code --weight-format fp16 --model TinyLlama/TinyLlama-1.1B-Chat-v1.0 TinyLlama-1.1B-Chat-v1.0
cmake -DCMAKE_BUILD_TYPE=Release -DENABLE_CONTINUOUS_BATCHING=ON -DENABLE_APPS=ON -S ./ -B ./build/
cmake --build ./build/ --config Release -j
- run: >
. ./ov/setupvars.sh
&& timeout 25s ./build/samples/cpp/accuracy_sample/accuracy_sample -m ./TinyLlama-1.1B-Chat-v1.0/ -n 4
# - run: >
# . ./ov/setupvars.sh
# && PYTHONPATH=./build/:$PYTHONPATH timeout 25s
# ./samples/python/multinomial_causal_lm/multinomial_causal_lm.py ./open_llama_3b_v2/ b
# - run: >
# . ./ov/setupvars.sh
# && export PYTHONPATH=./build/:$PYTHONPATH
# && timeout 25s ./build/samples/cpp/greedy_causal_lm/greedy_causal_lm ./open_llama_3b_v2/ "return 0"
# | diff <(timeout 25s samples/python/greedy_causal_lm/greedy_causal_lm.py ./open_llama_3b_v2/ "return 0") -

cpp-accuracy-sample-windows:
runs-on: windows-latest
defaults:
run:
shell: cmd
steps:
- uses: actions/checkout@v4
with:
submodules: recursive
- uses: actions/setup-python@v4
with:
python-version: 3.8
- run: curl --output ov.zip ${{ env.w_ov_link }}
- run: unzip -d ov ov.zip
- run: dirs=(ov/*) && mv ov/*/* ov && rmdir "${dirs[@]}"
shell: bash
- name: Download, convert and build
run: |
call .\ov\setupvars.bat
python -m pip install --upgrade-strategy eager -r ./samples/requirements.txt --pre --extra-index-url https://storage.openvinotoolkit.org/simple/wheels/nightly
python -m pip install ./thirdparty/openvino_tokenizers/[transformers] --pre --extra-index-url https://storage.openvinotoolkit.org/simple/wheels/nightly
optimum-cli export openvino --trust-remote-code --weight-format fp16 --model TinyLlama/TinyLlama-1.1B-Chat-v1.0 TinyLlama-1.1B-Chat-v1.0
cmake -DCMAKE_BUILD_TYPE=Release -DENABLE_CONTINUOUS_BATCHING=ON -DENABLE_APPS=ON -S ./ -B ./build/
cmake --build ./build/ --config Release -j
- run: >
set PATH=.\build\openvino_genai\;%PATH%
&& call .\ov\setupvars.bat
&& .\build\samples\cpp\accuracy_sample\Release\accuracy_sample.exe -m .\TinyLlama-1.1B-Chat-v1.0\ -n 4
# - run: |
# echo import transformers > ref.py
# echo predictions = open('cpp.txt', 'r').read() >> ref.py
# echo tokenizer = transformers.AutoTokenizer.from_pretrained('TinyLlama/TinyLlama-1.1B-Chat-v1.0', trust_remote_code=True) >> ref.py
# echo tokenized = tokenizer('69', return_tensors='pt') >> ref.py
# echo for beam in transformers.AutoModelForCausalLM.from_pretrained('TinyLlama/TinyLlama-1.1B-Chat-v1.0', trust_remote_code=True).generate(**tokenized, max_new_tokens=100, do_sample=False): >> ref.py
# echo ref = tokenizer.decode(beam[tokenized['input_ids'].numel():], skip_special_tokens=True) >> ref.py
# echo idx = predictions.find(ref) >> ref.py
# echo if -1 == idx: >> ref.py
# echo raise RuntimeError(f'Missing "{ref=}" from predictions') >> ref.py
# echo predictions = predictions[:idx] + predictions[idx + len(ref):] >> ref.py
# - run: python ref.py
# - run: >
# set PATH=.\build\openvino_genai\;%PATH%
# && set "PYTHONPATH=./build/"
# && call .\ov\setupvars.bat
# && python samples\python\greedy_causal_lm\greedy_causal_lm.py .\TinyLlama-1.1B-Chat-v1.0\ 69 > .\py.txt
# - run: fc .\cpp.txt .\py.txt

cpp-accuracy-sample-macos:
runs-on: macos-12
steps:
- uses: actions/checkout@v4
with:
submodules: recursive
- uses: actions/setup-python@v4
with:
python-version: 3.8
- name: Install OpenVINO
run: |
mkdir ./ov/
curl ${{ env.m_ov_link }} | tar --directory ./ov/ --strip-components 1 -xz
brew install coreutils scons
- name: Download, convert and build
run: |
source ./ov/setupvars.sh
python -m pip install --upgrade-strategy eager -r ./samples/requirements.txt --pre --extra-index-url https://storage.openvinotoolkit.org/simple/wheels/nightly
python -m pip install ./thirdparty/openvino_tokenizers/[transformers] --pre --extra-index-url https://storage.openvinotoolkit.org/simple/wheels/nightly
optimum-cli export openvino --trust-remote-code --weight-format fp16 --model TinyLlama/TinyLlama-1.1B-Chat-v1.0 TinyLlama-1.1B-Chat-v1.0
cmake -DCMAKE_BUILD_TYPE=Release -DENABLE_CONTINUOUS_BATCHING=ON -DENABLE_APPS=ON -S ./ -B ./build/
cmake --build ./build/ --config Release -j
- run: >
. ./ov/setupvars.sh
&& ./build/samples/cpp/accuracy_sample/accuracy_sample -m ./TinyLlama-1.1B-Chat-v1.0/ -n 4
Loading