* Start adding Reachy 2 (no camera) * Fix joint shape * Remove print * Modify observation_features * Fix observation state * Try adding a fake Reachy teleoperator * Saving test scripts * Add reachy2camera to cameras * Add teleop_left camera to observation * Create test_reachy2_camera.py * Update utils.py * Add all rgb cameras * Future depth work * Try adding mobile_base velocity * Update tests * Update data_acquisition_server.py * Update with use_external_commands * Replay * Usable with or without mobile base * No need for new isntance * Use same ip for cameras * Remove useless imports * Add resume * Divide joints in multiple dicts * Divide joinits into several dicts in teleoperator * Fix forgotten method call * Create test_robot_client.py * Open gripper on start * Add arguments for cameras * Modify get_frame() requested size * Call generate_joints_dict on _init_ * black + isort * Add reachy2 in imports * Add reachy2 dependencies * Add documentation * Update reachy2.mdx * Update reachy2.mdx * Clean files and add types * Fix type in send_action * Remove print * Delete test files * Clean code * Update cameras * Disconnect from camera * Run pre-commit hooks * Update pyproject.toml * Create test_reachy2.py * Fix generate_joints * Update test_reachy2.py * Update send_action test * Update reachy2_cameras depth + CameraManager * Update reachy2_camera tests * Remove useless import and args * Rename reachy2_teleoperator * Create test_reachy2_teleoperator.py * Fix remainging fake_teleoperator * Remove useless elements * Mock cameras in test_reachy2 * Delete commented lines * Add use_present_position to teleoperator * Add cameras tests * Add check no part + test * Use disable_torque_on_disconnect * Use odometry for vel with present_position * Update documentation * Fix vel value type * Use ensure_safe_goal_position * Import joints dict from classes * Update reachy2.mdx * Update reachy2.mdx * Update minimal version * Update minimal version * fix(tests) fixes for reachy2 tests; removing reachy2 references from the script * Add reachy2_sdk fake as plugins --------- Co-authored-by: Michel Aractingi <michel.aractingi@huggingface.co>
90 lines
2.6 KiB
Python
90 lines
2.6 KiB
Python
#!/usr/bin/env python
|
|
|
|
# Copyright 2024 The HuggingFace Inc. team. All rights reserved.
|
|
#
|
|
# Licensed 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 traceback
|
|
|
|
import pytest
|
|
from serial import SerialException
|
|
|
|
from lerobot.configs.types import FeatureType, PolicyFeature
|
|
from tests.utils import DEVICE
|
|
|
|
# Import fixture modules as plugins
|
|
pytest_plugins = [
|
|
"tests.fixtures.dataset_factories",
|
|
"tests.fixtures.files",
|
|
"tests.fixtures.hub",
|
|
"tests.fixtures.optimizers",
|
|
"tests.plugins.reachy2_sdk",
|
|
]
|
|
|
|
|
|
def pytest_collection_finish():
|
|
print(f"\nTesting with {DEVICE=}")
|
|
|
|
|
|
def _check_component_availability(component_type, available_components, make_component):
|
|
"""Generic helper to check if a hardware component is available"""
|
|
if component_type not in available_components:
|
|
raise ValueError(
|
|
f"The {component_type} type is not valid. Expected one of these '{available_components}'"
|
|
)
|
|
|
|
try:
|
|
component = make_component(component_type)
|
|
component.connect()
|
|
del component
|
|
return True
|
|
|
|
except Exception as e:
|
|
print(f"\nA {component_type} is not available.")
|
|
|
|
if isinstance(e, ModuleNotFoundError):
|
|
print(f"\nInstall module '{e.name}'")
|
|
elif isinstance(e, SerialException):
|
|
print("\nNo physical device detected.")
|
|
elif isinstance(e, ValueError) and "camera_index" in str(e):
|
|
print("\nNo physical camera detected.")
|
|
else:
|
|
traceback.print_exc()
|
|
|
|
return False
|
|
|
|
|
|
@pytest.fixture
|
|
def patch_builtins_input(monkeypatch):
|
|
def print_text(text=None):
|
|
if text is not None:
|
|
print(text)
|
|
|
|
monkeypatch.setattr("builtins.input", print_text)
|
|
|
|
|
|
@pytest.fixture
|
|
def policy_feature_factory():
|
|
"""PolicyFeature factory"""
|
|
|
|
def _pf(ft: FeatureType, shape: tuple[int, ...]) -> PolicyFeature:
|
|
return PolicyFeature(type=ft, shape=shape)
|
|
|
|
return _pf
|
|
|
|
|
|
def assert_contract_is_typed(features: dict[str, PolicyFeature]) -> None:
|
|
assert isinstance(features, dict)
|
|
assert all(isinstance(k, str) for k in features.keys())
|
|
assert all(isinstance(v, PolicyFeature) for v in features.values())
|