truss 0.10.0rc1__py3-none-any.whl → 0.60.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of truss might be problematic. Click here for more details.
- truss/__init__.py +10 -3
- truss/api/__init__.py +123 -0
- truss/api/definitions.py +51 -0
- truss/base/constants.py +116 -0
- truss/base/custom_types.py +29 -0
- truss/{errors.py → base/errors.py} +4 -0
- truss/base/trt_llm_config.py +310 -0
- truss/{truss_config.py → base/truss_config.py} +344 -31
- truss/{truss_spec.py → base/truss_spec.py} +20 -6
- truss/{validation.py → base/validation.py} +60 -11
- truss/cli/cli.py +841 -88
- truss/{remote → cli}/remote_cli.py +2 -7
- truss/contexts/docker_build_setup.py +67 -0
- truss/contexts/image_builder/cache_warmer.py +2 -8
- truss/contexts/image_builder/image_builder.py +1 -1
- truss/contexts/image_builder/serving_image_builder.py +292 -46
- truss/contexts/image_builder/util.py +1 -3
- truss/contexts/local_loader/docker_build_emulator.py +58 -0
- truss/contexts/local_loader/load_model_local.py +2 -2
- truss/contexts/local_loader/truss_module_loader.py +1 -1
- truss/contexts/local_loader/utils.py +1 -1
- truss/local/local_config.py +2 -6
- truss/local/local_config_handler.py +20 -5
- truss/patch/__init__.py +1 -0
- truss/patch/hash.py +4 -70
- truss/patch/signature.py +4 -16
- truss/patch/truss_dir_patch_applier.py +3 -78
- truss/remote/baseten/api.py +308 -23
- truss/remote/baseten/auth.py +3 -3
- truss/remote/baseten/core.py +257 -50
- truss/remote/baseten/custom_types.py +44 -0
- truss/remote/baseten/error.py +4 -0
- truss/remote/baseten/remote.py +369 -118
- truss/remote/baseten/service.py +118 -11
- truss/remote/baseten/utils/status.py +29 -0
- truss/remote/baseten/utils/tar.py +34 -22
- truss/remote/baseten/utils/transfer.py +36 -23
- truss/remote/remote_factory.py +14 -5
- truss/remote/truss_remote.py +72 -45
- truss/templates/base.Dockerfile.jinja +18 -16
- truss/templates/cache.Dockerfile.jinja +3 -3
- truss/{server → templates/control}/control/application.py +14 -35
- truss/{server → templates/control}/control/endpoints.py +39 -9
- truss/{server/control/patch/types.py → templates/control/control/helpers/custom_types.py} +13 -52
- truss/{server → templates/control}/control/helpers/inference_server_controller.py +4 -8
- truss/{server → templates/control}/control/helpers/inference_server_process_controller.py +2 -4
- truss/{server → templates/control}/control/helpers/inference_server_starter.py +5 -10
- truss/{server/control → templates/control/control/helpers}/truss_patch/model_code_patch_applier.py +8 -6
- truss/{server/control/patch → templates/control/control/helpers/truss_patch}/model_container_patch_applier.py +18 -26
- truss/templates/control/control/helpers/truss_patch/requirement_name_identifier.py +66 -0
- truss/{server → templates/control}/control/server.py +11 -6
- truss/templates/control/requirements.txt +9 -0
- truss/templates/custom_python_dx/my_model.py +28 -0
- truss/templates/docker_server/proxy.conf.jinja +42 -0
- truss/templates/docker_server/supervisord.conf.jinja +27 -0
- truss/templates/docker_server_requirements.txt +1 -0
- truss/templates/server/common/errors.py +231 -0
- truss/{server → templates/server}/common/patches/whisper/patch.py +1 -0
- truss/{server/common/patches/__init__.py → templates/server/common/patches.py} +1 -3
- truss/{server → templates/server}/common/retry.py +1 -0
- truss/{server → templates/server}/common/schema.py +11 -9
- truss/templates/server/common/tracing.py +157 -0
- truss/templates/server/main.py +9 -0
- truss/templates/server/model_wrapper.py +961 -0
- truss/templates/server/requirements.txt +21 -0
- truss/templates/server/truss_server.py +447 -0
- truss/templates/server.Dockerfile.jinja +62 -14
- truss/templates/shared/dynamic_config_resolver.py +28 -0
- truss/templates/shared/lazy_data_resolver.py +164 -0
- truss/templates/shared/log_config.py +125 -0
- truss/{server → templates}/shared/secrets_resolver.py +1 -2
- truss/{server → templates}/shared/serialization.py +31 -9
- truss/{server → templates}/shared/util.py +3 -13
- truss/templates/trtllm-audio/model/model.py +49 -0
- truss/templates/trtllm-audio/packages/sigint_patch.py +14 -0
- truss/templates/trtllm-audio/packages/whisper_trt/__init__.py +215 -0
- truss/templates/trtllm-audio/packages/whisper_trt/assets.py +25 -0
- truss/templates/trtllm-audio/packages/whisper_trt/batching.py +52 -0
- truss/templates/trtllm-audio/packages/whisper_trt/custom_types.py +26 -0
- truss/templates/trtllm-audio/packages/whisper_trt/modeling.py +184 -0
- truss/templates/trtllm-audio/packages/whisper_trt/tokenizer.py +185 -0
- truss/templates/trtllm-audio/packages/whisper_trt/utils.py +245 -0
- truss/templates/trtllm-briton/src/extension.py +64 -0
- truss/tests/conftest.py +302 -94
- truss/tests/contexts/image_builder/test_serving_image_builder.py +74 -31
- truss/tests/contexts/local_loader/test_load_local.py +2 -2
- truss/tests/contexts/local_loader/test_truss_module_finder.py +1 -1
- truss/tests/patch/test_calc_patch.py +439 -127
- truss/tests/patch/test_dir_signature.py +3 -12
- truss/tests/patch/test_hash.py +1 -1
- truss/tests/patch/test_signature.py +1 -1
- truss/tests/patch/test_truss_dir_patch_applier.py +23 -11
- truss/tests/patch/test_types.py +2 -2
- truss/tests/remote/baseten/test_api.py +153 -58
- truss/tests/remote/baseten/test_auth.py +2 -1
- truss/tests/remote/baseten/test_core.py +160 -12
- truss/tests/remote/baseten/test_remote.py +489 -77
- truss/tests/remote/baseten/test_service.py +55 -0
- truss/tests/remote/test_remote_factory.py +16 -18
- truss/tests/remote/test_truss_remote.py +26 -17
- truss/tests/templates/control/control/helpers/test_context_managers.py +11 -0
- truss/tests/templates/control/control/helpers/test_model_container_patch_applier.py +184 -0
- truss/tests/templates/control/control/helpers/test_requirement_name_identifier.py +89 -0
- truss/tests/{server → templates/control}/control/test_server.py +79 -24
- truss/tests/{server → templates/control}/control/test_server_integration.py +24 -16
- truss/tests/templates/core/server/test_dynamic_config_resolver.py +108 -0
- truss/tests/templates/core/server/test_lazy_data_resolver.py +329 -0
- truss/tests/templates/core/server/test_lazy_data_resolver_v2.py +79 -0
- truss/tests/{server → templates}/core/server/test_secrets_resolver.py +1 -1
- truss/tests/{server → templates/server}/common/test_retry.py +3 -3
- truss/tests/templates/server/test_model_wrapper.py +248 -0
- truss/tests/{server → templates/server}/test_schema.py +3 -5
- truss/tests/{server/core/server/common → templates/server}/test_truss_server.py +8 -5
- truss/tests/test_build.py +9 -52
- truss/tests/test_config.py +336 -77
- truss/tests/test_context_builder_image.py +3 -11
- truss/tests/test_control_truss_patching.py +7 -12
- truss/tests/test_custom_server.py +38 -0
- truss/tests/test_data/context_builder_image_test/test.py +3 -0
- truss/tests/test_data/happy.ipynb +56 -0
- truss/tests/test_data/model_load_failure_test/config.yaml +2 -0
- truss/tests/test_data/model_load_failure_test/model/__init__.py +0 -0
- truss/tests/test_data/patch_ping_test_server/__init__.py +0 -0
- truss/{test_data → tests/test_data}/patch_ping_test_server/app.py +3 -9
- truss/{test_data → tests/test_data}/server.Dockerfile +20 -21
- truss/tests/test_data/server_conformance_test_truss/__init__.py +0 -0
- truss/tests/test_data/server_conformance_test_truss/model/__init__.py +0 -0
- truss/{test_data → tests/test_data}/server_conformance_test_truss/model/model.py +1 -3
- truss/tests/test_data/test_async_truss/__init__.py +0 -0
- truss/tests/test_data/test_async_truss/model/__init__.py +0 -0
- truss/tests/test_data/test_basic_truss/__init__.py +0 -0
- truss/tests/test_data/test_basic_truss/config.yaml +16 -0
- truss/tests/test_data/test_basic_truss/model/__init__.py +0 -0
- truss/tests/test_data/test_build_commands/__init__.py +0 -0
- truss/tests/test_data/test_build_commands/config.yaml +13 -0
- truss/tests/test_data/test_build_commands/model/__init__.py +0 -0
- truss/{test_data/test_streaming_async_generator_truss → tests/test_data/test_build_commands}/model/model.py +2 -3
- truss/tests/test_data/test_build_commands_failure/__init__.py +0 -0
- truss/tests/test_data/test_build_commands_failure/config.yaml +14 -0
- truss/tests/test_data/test_build_commands_failure/model/__init__.py +0 -0
- truss/tests/test_data/test_build_commands_failure/model/model.py +17 -0
- truss/tests/test_data/test_concurrency_truss/__init__.py +0 -0
- truss/tests/test_data/test_concurrency_truss/config.yaml +4 -0
- truss/tests/test_data/test_concurrency_truss/model/__init__.py +0 -0
- truss/tests/test_data/test_custom_server_truss/__init__.py +0 -0
- truss/tests/test_data/test_custom_server_truss/config.yaml +20 -0
- truss/tests/test_data/test_custom_server_truss/test_docker_image/Dockerfile +17 -0
- truss/tests/test_data/test_custom_server_truss/test_docker_image/README.md +10 -0
- truss/tests/test_data/test_custom_server_truss/test_docker_image/VERSION +1 -0
- truss/tests/test_data/test_custom_server_truss/test_docker_image/__init__.py +0 -0
- truss/tests/test_data/test_custom_server_truss/test_docker_image/app.py +19 -0
- truss/tests/test_data/test_custom_server_truss/test_docker_image/build_upload_new_image.sh +6 -0
- truss/tests/test_data/test_openai/__init__.py +0 -0
- truss/{test_data/test_basic_truss → tests/test_data/test_openai}/config.yaml +1 -2
- truss/tests/test_data/test_openai/model/__init__.py +0 -0
- truss/tests/test_data/test_openai/model/model.py +15 -0
- truss/tests/test_data/test_pyantic_v1/__init__.py +0 -0
- truss/tests/test_data/test_pyantic_v1/model/__init__.py +0 -0
- truss/tests/test_data/test_pyantic_v1/model/model.py +28 -0
- truss/tests/test_data/test_pyantic_v1/requirements.txt +1 -0
- truss/tests/test_data/test_pyantic_v2/__init__.py +0 -0
- truss/tests/test_data/test_pyantic_v2/config.yaml +13 -0
- truss/tests/test_data/test_pyantic_v2/model/__init__.py +0 -0
- truss/tests/test_data/test_pyantic_v2/model/model.py +30 -0
- truss/tests/test_data/test_pyantic_v2/requirements.txt +1 -0
- truss/tests/test_data/test_requirements_file_truss/__init__.py +0 -0
- truss/tests/test_data/test_requirements_file_truss/config.yaml +13 -0
- truss/tests/test_data/test_requirements_file_truss/model/__init__.py +0 -0
- truss/{test_data → tests/test_data}/test_requirements_file_truss/model/model.py +1 -0
- truss/tests/test_data/test_streaming_async_generator_truss/__init__.py +0 -0
- truss/tests/test_data/test_streaming_async_generator_truss/config.yaml +4 -0
- truss/tests/test_data/test_streaming_async_generator_truss/model/__init__.py +0 -0
- truss/tests/test_data/test_streaming_async_generator_truss/model/model.py +7 -0
- truss/tests/test_data/test_streaming_read_timeout/__init__.py +0 -0
- truss/tests/test_data/test_streaming_read_timeout/model/__init__.py +0 -0
- truss/tests/test_data/test_streaming_truss/__init__.py +0 -0
- truss/tests/test_data/test_streaming_truss/config.yaml +4 -0
- truss/tests/test_data/test_streaming_truss/model/__init__.py +0 -0
- truss/tests/test_data/test_streaming_truss_with_error/__init__.py +0 -0
- truss/tests/test_data/test_streaming_truss_with_error/model/__init__.py +0 -0
- truss/{test_data → tests/test_data}/test_streaming_truss_with_error/model/model.py +3 -11
- truss/tests/test_data/test_streaming_truss_with_error/packages/__init__.py +0 -0
- truss/tests/test_data/test_streaming_truss_with_error/packages/helpers_1.py +5 -0
- truss/tests/test_data/test_streaming_truss_with_error/packages/helpers_2.py +2 -0
- truss/tests/test_data/test_streaming_truss_with_tracing/__init__.py +0 -0
- truss/tests/test_data/test_streaming_truss_with_tracing/config.yaml +43 -0
- truss/tests/test_data/test_streaming_truss_with_tracing/model/__init__.py +0 -0
- truss/tests/test_data/test_streaming_truss_with_tracing/model/model.py +65 -0
- truss/tests/test_data/test_trt_llm_truss/__init__.py +0 -0
- truss/tests/test_data/test_trt_llm_truss/config.yaml +15 -0
- truss/tests/test_data/test_trt_llm_truss/model/__init__.py +0 -0
- truss/tests/test_data/test_trt_llm_truss/model/model.py +15 -0
- truss/tests/test_data/test_truss/__init__.py +0 -0
- truss/tests/test_data/test_truss/config.yaml +4 -0
- truss/tests/test_data/test_truss/model/__init__.py +0 -0
- truss/tests/test_data/test_truss/model/dummy +0 -0
- truss/tests/test_data/test_truss/packages/__init__.py +0 -0
- truss/tests/test_data/test_truss/packages/test_package/__init__.py +0 -0
- truss/tests/test_data/test_truss_server_caching_truss/__init__.py +0 -0
- truss/tests/test_data/test_truss_server_caching_truss/model/__init__.py +0 -0
- truss/tests/test_data/test_truss_with_error/__init__.py +0 -0
- truss/tests/test_data/test_truss_with_error/config.yaml +4 -0
- truss/tests/test_data/test_truss_with_error/model/__init__.py +0 -0
- truss/tests/test_data/test_truss_with_error/model/model.py +8 -0
- truss/tests/test_data/test_truss_with_error/packages/__init__.py +0 -0
- truss/tests/test_data/test_truss_with_error/packages/helpers_1.py +5 -0
- truss/tests/test_data/test_truss_with_error/packages/helpers_2.py +2 -0
- truss/tests/test_docker.py +2 -1
- truss/tests/test_model_inference.py +1340 -292
- truss/tests/test_model_schema.py +33 -26
- truss/tests/test_testing_utilities_for_other_tests.py +50 -5
- truss/tests/test_truss_gatherer.py +3 -5
- truss/tests/test_truss_handle.py +62 -59
- truss/tests/test_util.py +2 -1
- truss/tests/test_validation.py +15 -13
- truss/tests/trt_llm/test_trt_llm_config.py +41 -0
- truss/tests/trt_llm/test_validation.py +91 -0
- truss/tests/util/test_config_checks.py +40 -0
- truss/tests/util/test_env_vars.py +14 -0
- truss/tests/util/test_path.py +10 -23
- truss/trt_llm/config_checks.py +43 -0
- truss/trt_llm/validation.py +42 -0
- truss/truss_handle/__init__.py +0 -0
- truss/truss_handle/build.py +122 -0
- truss/{decorators.py → truss_handle/decorators.py} +1 -1
- truss/truss_handle/patch/__init__.py +0 -0
- truss/{patch → truss_handle/patch}/calc_patch.py +146 -92
- truss/{types.py → truss_handle/patch/custom_types.py} +35 -27
- truss/{patch → truss_handle/patch}/dir_signature.py +1 -1
- truss/truss_handle/patch/hash.py +71 -0
- truss/{patch → truss_handle/patch}/local_truss_patch_applier.py +6 -4
- truss/truss_handle/patch/signature.py +22 -0
- truss/truss_handle/patch/truss_dir_patch_applier.py +87 -0
- truss/{readme_generator.py → truss_handle/readme_generator.py} +3 -2
- truss/{truss_gatherer.py → truss_handle/truss_gatherer.py} +3 -2
- truss/{truss_handle.py → truss_handle/truss_handle.py} +174 -78
- truss/util/.truss_ignore +3 -0
- truss/{docker.py → util/docker.py} +6 -2
- truss/util/download.py +6 -15
- truss/util/env_vars.py +41 -0
- truss/util/log_utils.py +52 -0
- truss/util/path.py +20 -20
- truss/util/requirements.py +11 -0
- {truss-0.10.0rc1.dist-info → truss-0.60.0.dist-info}/METADATA +18 -16
- truss-0.60.0.dist-info/RECORD +324 -0
- {truss-0.10.0rc1.dist-info → truss-0.60.0.dist-info}/WHEEL +1 -1
- truss-0.60.0.dist-info/entry_points.txt +4 -0
- truss_chains/__init__.py +71 -0
- truss_chains/definitions.py +756 -0
- truss_chains/deployment/__init__.py +0 -0
- truss_chains/deployment/code_gen.py +816 -0
- truss_chains/deployment/deployment_client.py +871 -0
- truss_chains/framework.py +1480 -0
- truss_chains/public_api.py +231 -0
- truss_chains/py.typed +0 -0
- truss_chains/pydantic_numpy.py +131 -0
- truss_chains/reference_code/reference_chainlet.py +34 -0
- truss_chains/reference_code/reference_model.py +10 -0
- truss_chains/remote_chainlet/__init__.py +0 -0
- truss_chains/remote_chainlet/model_skeleton.py +60 -0
- truss_chains/remote_chainlet/stub.py +380 -0
- truss_chains/remote_chainlet/utils.py +332 -0
- truss_chains/streaming.py +378 -0
- truss_chains/utils.py +178 -0
- CODE_OF_CONDUCT.md +0 -131
- CONTRIBUTING.md +0 -48
- README.md +0 -137
- context_builder.Dockerfile +0 -24
- truss/blob/blob_backend.py +0 -10
- truss/blob/blob_backend_registry.py +0 -23
- truss/blob/http_public_blob_backend.py +0 -23
- truss/build/__init__.py +0 -2
- truss/build/build.py +0 -143
- truss/build/configure.py +0 -63
- truss/cli/__init__.py +0 -2
- truss/cli/console.py +0 -5
- truss/cli/create.py +0 -5
- truss/config/trt_llm.py +0 -81
- truss/constants.py +0 -61
- truss/model_inference.py +0 -123
- truss/patch/types.py +0 -30
- truss/pytest.ini +0 -7
- truss/server/common/errors.py +0 -100
- truss/server/common/termination_handler_middleware.py +0 -64
- truss/server/common/truss_server.py +0 -389
- truss/server/control/patch/model_code_patch_applier.py +0 -46
- truss/server/control/patch/requirement_name_identifier.py +0 -17
- truss/server/inference_server.py +0 -29
- truss/server/model_wrapper.py +0 -434
- truss/server/shared/logging.py +0 -81
- truss/templates/trtllm/model/model.py +0 -97
- truss/templates/trtllm/packages/build_engine_utils.py +0 -34
- truss/templates/trtllm/packages/constants.py +0 -11
- truss/templates/trtllm/packages/schema.py +0 -216
- truss/templates/trtllm/packages/tensorrt_llm_model_repository/ensemble/config.pbtxt +0 -246
- truss/templates/trtllm/packages/tensorrt_llm_model_repository/postprocessing/1/model.py +0 -181
- truss/templates/trtllm/packages/tensorrt_llm_model_repository/postprocessing/config.pbtxt +0 -64
- truss/templates/trtllm/packages/tensorrt_llm_model_repository/preprocessing/1/model.py +0 -260
- truss/templates/trtllm/packages/tensorrt_llm_model_repository/preprocessing/config.pbtxt +0 -99
- truss/templates/trtllm/packages/tensorrt_llm_model_repository/tensorrt_llm/config.pbtxt +0 -208
- truss/templates/trtllm/packages/triton_client.py +0 -150
- truss/templates/trtllm/packages/utils.py +0 -43
- truss/test_data/context_builder_image_test/test.py +0 -4
- truss/test_data/happy.ipynb +0 -54
- truss/test_data/model_load_failure_test/config.yaml +0 -2
- truss/test_data/test_concurrency_truss/config.yaml +0 -2
- truss/test_data/test_streaming_async_generator_truss/config.yaml +0 -2
- truss/test_data/test_streaming_truss/config.yaml +0 -3
- truss/test_data/test_truss/config.yaml +0 -2
- truss/tests/server/common/test_termination_handler_middleware.py +0 -93
- truss/tests/server/control/test_model_container_patch_applier.py +0 -203
- truss/tests/server/core/server/common/test_util.py +0 -19
- truss/tests/server/test_model_wrapper.py +0 -87
- truss/util/data_structures.py +0 -16
- truss-0.10.0rc1.dist-info/RECORD +0 -216
- truss-0.10.0rc1.dist-info/entry_points.txt +0 -3
- truss/{server/shared → base}/__init__.py +0 -0
- truss/{server → templates/control}/control/helpers/context_managers.py +0 -0
- truss/{server/control → templates/control/control/helpers}/errors.py +0 -0
- truss/{server/control/patch → templates/control/control/helpers/truss_patch}/__init__.py +0 -0
- truss/{server/control/patch → templates/control/control/helpers/truss_patch}/system_packages.py +0 -0
- truss/{test_data/annotated_types_truss/model → templates/server}/__init__.py +0 -0
- truss/{server → templates/server}/common/__init__.py +0 -0
- truss/{test_data/gcs_fix/model → templates/shared}/__init__.py +0 -0
- truss/templates/{trtllm → trtllm-briton}/README.md +0 -0
- truss/{test_data/server_conformance_test_truss/model → tests/test_data}/__init__.py +0 -0
- truss/{test_data/test_basic_truss/model → tests/test_data/annotated_types_truss}/__init__.py +0 -0
- truss/{test_data → tests/test_data}/annotated_types_truss/config.yaml +0 -0
- truss/{test_data/test_requirements_file_truss → tests/test_data/annotated_types_truss}/model/__init__.py +0 -0
- truss/{test_data → tests/test_data}/annotated_types_truss/model/model.py +0 -0
- truss/{test_data → tests/test_data}/auto-mpg.data +0 -0
- truss/{test_data → tests/test_data}/context_builder_image_test/Dockerfile +0 -0
- truss/{test_data/test_truss/model → tests/test_data/context_builder_image_test}/__init__.py +0 -0
- truss/{test_data/test_truss_server_caching_truss/model → tests/test_data/gcs_fix}/__init__.py +0 -0
- truss/{test_data → tests/test_data}/gcs_fix/config.yaml +0 -0
- truss/tests/{local → test_data/gcs_fix/model}/__init__.py +0 -0
- truss/{test_data → tests/test_data}/gcs_fix/model/model.py +0 -0
- truss/{test_data/test_truss/model/dummy → tests/test_data/model_load_failure_test/__init__.py} +0 -0
- truss/{test_data → tests/test_data}/model_load_failure_test/model/model.py +0 -0
- truss/{test_data → tests/test_data}/pima-indians-diabetes.csv +0 -0
- truss/{test_data → tests/test_data}/readme_int_example.md +0 -0
- truss/{test_data → tests/test_data}/readme_no_example.md +0 -0
- truss/{test_data → tests/test_data}/readme_str_example.md +0 -0
- truss/{test_data → tests/test_data}/server_conformance_test_truss/config.yaml +0 -0
- truss/{test_data → tests/test_data}/test_async_truss/config.yaml +0 -0
- truss/{test_data → tests/test_data}/test_async_truss/model/model.py +3 -3
- /truss/{test_data → tests/test_data}/test_basic_truss/model/model.py +0 -0
- /truss/{test_data → tests/test_data}/test_concurrency_truss/model/model.py +0 -0
- /truss/{test_data/test_requirements_file_truss → tests/test_data/test_pyantic_v1}/config.yaml +0 -0
- /truss/{test_data → tests/test_data}/test_requirements_file_truss/requirements.txt +0 -0
- /truss/{test_data → tests/test_data}/test_streaming_read_timeout/config.yaml +0 -0
- /truss/{test_data → tests/test_data}/test_streaming_read_timeout/model/model.py +0 -0
- /truss/{test_data → tests/test_data}/test_streaming_truss/model/model.py +0 -0
- /truss/{test_data → tests/test_data}/test_streaming_truss_with_error/config.yaml +0 -0
- /truss/{test_data → tests/test_data}/test_truss/examples.yaml +0 -0
- /truss/{test_data → tests/test_data}/test_truss/model/model.py +0 -0
- /truss/{test_data → tests/test_data}/test_truss/packages/test_package/test.py +0 -0
- /truss/{test_data → tests/test_data}/test_truss_server_caching_truss/config.yaml +0 -0
- /truss/{test_data → tests/test_data}/test_truss_server_caching_truss/model/model.py +0 -0
- /truss/{patch → truss_handle/patch}/constants.py +0 -0
- /truss/{notebook.py → util/notebook.py} +0 -0
- {truss-0.10.0rc1.dist-info → truss-0.60.0.dist-info}/LICENSE +0 -0
|
@@ -1,35 +1,45 @@
|
|
|
1
|
+
import filecmp
|
|
2
|
+
import os
|
|
1
3
|
import time
|
|
2
4
|
from pathlib import Path
|
|
3
5
|
from tempfile import TemporaryDirectory
|
|
4
6
|
from unittest.mock import patch
|
|
5
7
|
|
|
6
8
|
import pytest
|
|
9
|
+
from truss.base.constants import (
|
|
10
|
+
BASE_TRTLLM_REQUIREMENTS,
|
|
11
|
+
TRTLLM_BASE_IMAGE,
|
|
12
|
+
TRTLLM_PREDICT_CONCURRENCY,
|
|
13
|
+
TRTLLM_PYTHON_EXECUTABLE,
|
|
14
|
+
TRTLLM_TRUSS_DIR,
|
|
15
|
+
)
|
|
16
|
+
from truss.base.truss_config import ModelCache, ModelRepo, TrussConfig
|
|
7
17
|
from truss.contexts.image_builder.serving_image_builder import (
|
|
8
18
|
HF_ACCESS_TOKEN_FILE_NAME,
|
|
9
19
|
ServingImageBuilderContext,
|
|
10
20
|
get_files_to_cache,
|
|
11
21
|
)
|
|
12
22
|
from truss.tests.test_testing_utilities_for_other_tests import ensure_kill_all
|
|
13
|
-
from truss.
|
|
14
|
-
from truss.truss_handle import TrussHandle
|
|
23
|
+
from truss.truss_handle.truss_handle import TrussHandle
|
|
15
24
|
|
|
16
25
|
BASE_DIR = Path(__file__).parent
|
|
17
26
|
|
|
18
27
|
|
|
19
|
-
def test_serving_image_dockerfile_from_user_base_image(
|
|
28
|
+
def test_serving_image_dockerfile_from_user_base_image(
|
|
29
|
+
test_data_path, custom_model_truss_dir
|
|
30
|
+
):
|
|
20
31
|
th = TrussHandle(custom_model_truss_dir)
|
|
32
|
+
# The test fixture python varies with host version, need to pin here.
|
|
33
|
+
th.update_python_version("py39")
|
|
21
34
|
th.set_base_image("baseten/truss-server-base:3.9-v0.4.3", "/usr/local/bin/python3")
|
|
22
|
-
|
|
23
|
-
image_builder =
|
|
35
|
+
builder_context = ServingImageBuilderContext
|
|
36
|
+
image_builder = builder_context.run(th.spec.truss_dir)
|
|
24
37
|
with TemporaryDirectory() as tmp_dir:
|
|
25
38
|
tmp_path = Path(tmp_dir)
|
|
26
39
|
image_builder.prepare_image_build_dir(tmp_path)
|
|
27
40
|
with open(tmp_path / "Dockerfile", "r") as f:
|
|
28
41
|
gen_docker_lines = f.readlines()
|
|
29
|
-
with open(
|
|
30
|
-
f"{BASE_DIR}/../../../test_data/server.Dockerfile",
|
|
31
|
-
"r",
|
|
32
|
-
) as f:
|
|
42
|
+
with open(test_data_path / "server.Dockerfile", "r") as f:
|
|
33
43
|
server_docker_lines = f.readlines()
|
|
34
44
|
|
|
35
45
|
def filter_empty_lines(lines):
|
|
@@ -43,7 +53,8 @@ def test_serving_image_dockerfile_from_user_base_image(custom_model_truss_dir):
|
|
|
43
53
|
def test_requirements_setup_in_build_dir(custom_model_truss_dir):
|
|
44
54
|
th = TrussHandle(custom_model_truss_dir)
|
|
45
55
|
th.add_python_requirement("numpy")
|
|
46
|
-
|
|
56
|
+
builder_context = ServingImageBuilderContext
|
|
57
|
+
image_builder = builder_context.run(th.spec.truss_dir)
|
|
47
58
|
|
|
48
59
|
with TemporaryDirectory() as tmp_dir:
|
|
49
60
|
tmp_path = Path(tmp_dir)
|
|
@@ -51,8 +62,10 @@ def test_requirements_setup_in_build_dir(custom_model_truss_dir):
|
|
|
51
62
|
with open(tmp_path / "requirements.txt", "r") as f:
|
|
52
63
|
requirements_content = f.read()
|
|
53
64
|
|
|
54
|
-
|
|
55
|
-
|
|
65
|
+
with open(f"{BASE_DIR}/../../../templates/server/requirements.txt", "r") as f:
|
|
66
|
+
base_requirements_content = f.read()
|
|
67
|
+
|
|
68
|
+
assert requirements_content == base_requirements_content + "numpy\n"
|
|
56
69
|
|
|
57
70
|
|
|
58
71
|
def flatten_cached_files(local_cache_files):
|
|
@@ -62,8 +75,7 @@ def flatten_cached_files(local_cache_files):
|
|
|
62
75
|
def test_correct_hf_files_accessed_for_caching():
|
|
63
76
|
model = "openai/whisper-small"
|
|
64
77
|
config = TrussConfig(
|
|
65
|
-
python_version="py39",
|
|
66
|
-
model_cache=ModelCache(models=[ModelRepo(repo_id=model)]),
|
|
78
|
+
python_version="py39", model_cache=ModelCache(models=[ModelRepo(repo_id=model)])
|
|
67
79
|
)
|
|
68
80
|
|
|
69
81
|
with TemporaryDirectory() as tmp_dir:
|
|
@@ -98,8 +110,7 @@ def test_correct_gcs_files_accessed_for_caching(mock_list_bucket_files):
|
|
|
98
110
|
model = "gs://crazy-good-new-model-7b"
|
|
99
111
|
|
|
100
112
|
config = TrussConfig(
|
|
101
|
-
python_version="py39",
|
|
102
|
-
model_cache=ModelCache(models=[ModelRepo(repo_id=model)]),
|
|
113
|
+
python_version="py39", model_cache=ModelCache(models=[ModelRepo(repo_id=model)])
|
|
103
114
|
)
|
|
104
115
|
|
|
105
116
|
with TemporaryDirectory() as tmp_dir:
|
|
@@ -132,8 +143,7 @@ def test_correct_s3_files_accessed_for_caching(mock_list_bucket_files):
|
|
|
132
143
|
model = "s3://crazy-good-new-model-7b"
|
|
133
144
|
|
|
134
145
|
config = TrussConfig(
|
|
135
|
-
python_version="py39",
|
|
136
|
-
model_cache=ModelCache(models=[ModelRepo(repo_id=model)]),
|
|
146
|
+
python_version="py39", model_cache=ModelCache(models=[ModelRepo(repo_id=model)])
|
|
137
147
|
)
|
|
138
148
|
|
|
139
149
|
with TemporaryDirectory() as tmp_dir:
|
|
@@ -166,8 +176,7 @@ def test_correct_nested_gcs_files_accessed_for_caching(mock_list_bucket_files):
|
|
|
166
176
|
model = "gs://crazy-good-new-model-7b/folder_a/folder_b"
|
|
167
177
|
|
|
168
178
|
config = TrussConfig(
|
|
169
|
-
python_version="py39",
|
|
170
|
-
model_cache=ModelCache(models=[ModelRepo(repo_id=model)]),
|
|
179
|
+
python_version="py39", model_cache=ModelCache(models=[ModelRepo(repo_id=model)])
|
|
171
180
|
)
|
|
172
181
|
|
|
173
182
|
with TemporaryDirectory() as tmp_dir:
|
|
@@ -204,8 +213,7 @@ def test_correct_nested_s3_files_accessed_for_caching(mock_list_bucket_files):
|
|
|
204
213
|
model = "s3://crazy-good-new-model-7b/folder_a/folder_b"
|
|
205
214
|
|
|
206
215
|
config = TrussConfig(
|
|
207
|
-
python_version="py39",
|
|
208
|
-
model_cache=ModelCache(models=[ModelRepo(repo_id=model)]),
|
|
216
|
+
python_version="py39", model_cache=ModelCache(models=[ModelRepo(repo_id=model)])
|
|
209
217
|
)
|
|
210
218
|
|
|
211
219
|
with TemporaryDirectory() as tmp_dir:
|
|
@@ -234,24 +242,20 @@ def test_correct_nested_s3_files_accessed_for_caching(mock_list_bucket_files):
|
|
|
234
242
|
|
|
235
243
|
|
|
236
244
|
@pytest.mark.integration
|
|
237
|
-
def test_truss_server_caching_truss():
|
|
245
|
+
def test_truss_server_caching_truss(test_data_path):
|
|
238
246
|
with ensure_kill_all():
|
|
239
|
-
|
|
240
|
-
Path(__file__).parent.parent.parent.parent.parent.resolve() / "truss"
|
|
241
|
-
)
|
|
242
|
-
truss_dir = truss_root / "test_data" / "test_truss_server_caching_truss"
|
|
247
|
+
truss_dir = test_data_path / "test_truss_server_caching_truss"
|
|
243
248
|
tr = TrussHandle(truss_dir)
|
|
244
249
|
|
|
245
250
|
container = tr.docker_run(
|
|
246
|
-
local_port=8090, detach=True, wait_for_server_ready=True
|
|
251
|
+
local_port=8090, detach=True, wait_for_server_ready=True, network="host"
|
|
247
252
|
)
|
|
248
253
|
time.sleep(15)
|
|
249
254
|
assert "Downloading model.safetensors:" not in container.logs()
|
|
250
255
|
|
|
251
256
|
|
|
252
|
-
def test_model_cache_dockerfile():
|
|
253
|
-
|
|
254
|
-
truss_dir = truss_root / "test_data" / "test_truss_server_caching_truss"
|
|
257
|
+
def test_model_cache_dockerfile(test_data_path):
|
|
258
|
+
truss_dir = test_data_path / "test_truss_server_caching_truss"
|
|
255
259
|
tr = TrussHandle(truss_dir)
|
|
256
260
|
|
|
257
261
|
builder_context = ServingImageBuilderContext
|
|
@@ -285,3 +289,42 @@ def test_ignore_files_during_build_setup(custom_model_truss_dir_with_truss_ignor
|
|
|
285
289
|
|
|
286
290
|
assert not (build_path / ignore_folder).exists()
|
|
287
291
|
assert (build_path / do_not_ignore_folder).exists()
|
|
292
|
+
|
|
293
|
+
|
|
294
|
+
def test_trt_llm_build_dir(custom_model_trt_llm):
|
|
295
|
+
th = TrussHandle(custom_model_trt_llm)
|
|
296
|
+
builder_context = ServingImageBuilderContext
|
|
297
|
+
image_builder = builder_context.run(th.spec.truss_dir)
|
|
298
|
+
with TemporaryDirectory() as tmp_dir:
|
|
299
|
+
tmp_path = Path(tmp_dir)
|
|
300
|
+
image_builder.prepare_image_build_dir(tmp_path)
|
|
301
|
+
build_th = TrussHandle(tmp_path)
|
|
302
|
+
|
|
303
|
+
# Check that all files were copied
|
|
304
|
+
_assert_copied(
|
|
305
|
+
TRTLLM_TRUSS_DIR / "src", tmp_path / "server" / "extensions" / "trt_llm"
|
|
306
|
+
)
|
|
307
|
+
_assert_copied(TRTLLM_TRUSS_DIR / "packages", tmp_path / "packages")
|
|
308
|
+
|
|
309
|
+
assert (
|
|
310
|
+
build_th.spec.config.runtime.predict_concurrency
|
|
311
|
+
== TRTLLM_PREDICT_CONCURRENCY
|
|
312
|
+
)
|
|
313
|
+
assert build_th.spec.config.base_image.image == TRTLLM_BASE_IMAGE
|
|
314
|
+
assert (
|
|
315
|
+
build_th.spec.config.base_image.python_executable_path
|
|
316
|
+
== TRTLLM_PYTHON_EXECUTABLE
|
|
317
|
+
)
|
|
318
|
+
assert BASE_TRTLLM_REQUIREMENTS == build_th.spec.config.requirements
|
|
319
|
+
|
|
320
|
+
|
|
321
|
+
def _assert_copied(src_path: str, dest_path: str):
|
|
322
|
+
for dirpath, dirnames, filenames in os.walk(src_path):
|
|
323
|
+
rel_path = os.path.relpath(dirpath, src_path)
|
|
324
|
+
for filename in filenames:
|
|
325
|
+
src_file = os.path.join(dirpath, filename)
|
|
326
|
+
dest_file = os.path.join(dest_path, rel_path, filename)
|
|
327
|
+
assert os.path.exists(dest_file), f"{dest_file} was not copied"
|
|
328
|
+
assert filecmp.cmp(src_file, dest_file, shallow=False), (
|
|
329
|
+
f"{src_file} and {dest_file} are not the same"
|
|
330
|
+
)
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
+
from truss.base.truss_spec import TrussSpec
|
|
1
2
|
from truss.contexts.local_loader.utils import prepare_secrets
|
|
2
3
|
from truss.local.local_config_handler import LocalConfigHandler
|
|
3
|
-
from truss.truss_handle import TrussHandle
|
|
4
|
-
from truss.truss_spec import TrussSpec
|
|
4
|
+
from truss.truss_handle.truss_handle import TrussHandle
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
def test_prepare_secrets(custom_model_truss_dir, tmp_path):
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import tempfile
|
|
2
2
|
from pathlib import Path
|
|
3
3
|
|
|
4
|
+
from truss.base.truss_config import DEFAULT_BUNDLED_PACKAGES_DIR
|
|
4
5
|
from truss.contexts.local_loader.truss_module_loader import truss_module_loaded
|
|
5
|
-
from truss.truss_config import DEFAULT_BUNDLED_PACKAGES_DIR
|
|
6
6
|
|
|
7
7
|
ORIG_MODEL_CLASS_CONTENT = """
|
|
8
8
|
class Model:
|