mirror of
https://github.com/snakers4/silero-vad.git
synced 2026-02-04 17:39:22 +08:00
37
.github/workflows/test.yml
vendored
Normal file
37
.github/workflows/test.yml
vendored
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
name: Test Package
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch: # запуск вручную
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master # или любая тестовая ветка
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
os: [ubuntu-latest, windows-latest]
|
||||||
|
python-version: [3.8,3.9,3.10,3.11,3.12,3.13]
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Set up Python
|
||||||
|
uses: actions/setup-python@v4
|
||||||
|
with:
|
||||||
|
python-version: ${{ matrix.python-version }}
|
||||||
|
|
||||||
|
- name: Install dependencies
|
||||||
|
run: |
|
||||||
|
python -m pip install --upgrade pip
|
||||||
|
pip install hatchling pytest
|
||||||
|
|
||||||
|
- name: Build package
|
||||||
|
run: python -m build --wheel --outdir dist
|
||||||
|
|
||||||
|
- name: Install package
|
||||||
|
run: pip install dist/*.whl
|
||||||
|
|
||||||
|
- name: Run tests
|
||||||
|
run: pytest tests
|
||||||
BIN
tests/data/test.mp3
Normal file
BIN
tests/data/test.mp3
Normal file
Binary file not shown.
BIN
tests/data/test.opus
Normal file
BIN
tests/data/test.opus
Normal file
Binary file not shown.
BIN
tests/data/test.wav
Normal file
BIN
tests/data/test.wav
Normal file
Binary file not shown.
22
tests/test_basic.py
Normal file
22
tests/test_basic.py
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
from silero_vad import load_silero_vad, read_audio, get_speech_timestamps
|
||||||
|
import torch
|
||||||
|
torch.set_num_threads(1)
|
||||||
|
|
||||||
|
def test_jit_model():
|
||||||
|
model = load_silero_vad(onnx=False)
|
||||||
|
for path in ["tests/data/test.wav", "tests/data/test.opus", "tests/data/test.mp3"]:
|
||||||
|
audio = read_audio(path, sampling_rate=16000)
|
||||||
|
speech_timestamps = get_speech_timestamps(audio, model, visualize_probs=False, return_seconds=True)
|
||||||
|
assert speech_timestamps is not None
|
||||||
|
out = model.audio_forward(audio, sr=16000)
|
||||||
|
assert out is not None
|
||||||
|
|
||||||
|
def test_onnx_model():
|
||||||
|
model = load_silero_vad(onnx=True)
|
||||||
|
for path in ["tests/data/test.wav", "tests/data/test.opus", "tests/data/test.mp3"]:
|
||||||
|
audio = read_audio(path, sampling_rate=16000)
|
||||||
|
speech_timestamps = get_speech_timestamps(audio, model, visualize_probs=False, return_seconds=True)
|
||||||
|
assert speech_timestamps is not None
|
||||||
|
|
||||||
|
out = model.audio_forward(audio, sr=16000)
|
||||||
|
assert out is not None
|
||||||
Reference in New Issue
Block a user