2022-09-22 12:26:48 -07:00
|
|
|
# Copyright 2021 The JAX Authors.
|
2021-04-05 10:35:44 -07:00
|
|
|
#
|
|
|
|
# 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
|
|
|
|
#
|
|
|
|
# https://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.
|
2021-04-02 16:43:10 -07:00
|
|
|
"""pytest configuration"""
|
|
|
|
|
2022-11-17 05:33:54 +00:00
|
|
|
import os
|
2021-04-02 16:43:10 -07:00
|
|
|
import pytest
|
|
|
|
|
|
|
|
|
|
|
|
@pytest.fixture(autouse=True)
|
|
|
|
def add_imports(doctest_namespace):
|
2022-01-31 16:34:59 +00:00
|
|
|
import jax
|
|
|
|
import numpy
|
2021-04-02 16:43:10 -07:00
|
|
|
doctest_namespace["jax"] = jax
|
|
|
|
doctest_namespace["lax"] = jax.lax
|
|
|
|
doctest_namespace["jnp"] = jax.numpy
|
|
|
|
doctest_namespace["np"] = numpy
|
2022-11-17 05:33:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
# A pytest hook that runs immediately before test collection (i.e. when pytest
|
|
|
|
# loads all the test cases to run). When running parallel tests via xdist on
|
|
|
|
# Cloud TPU, we use this hook to set the env vars needed to run multiple test
|
|
|
|
# processes across different TPU chips.
|
|
|
|
#
|
|
|
|
# It's important that the hook runs before test collection, since jax tests end
|
|
|
|
# up initializing the TPU runtime on import (e.g. to query supported test
|
|
|
|
# types). It's also important that the hook gets called by each xdist worker
|
|
|
|
# process. Luckily each worker does its own test collection.
|
|
|
|
#
|
|
|
|
# The pytest_collection hook can be used to overwrite the collection logic, but
|
|
|
|
# we only use it to set the env vars and fall back to the default collection
|
|
|
|
# logic by always returning None. See
|
|
|
|
# https://docs.pytest.org/en/latest/how-to/writing_hook_functions.html#firstresult-stop-at-first-non-none-result
|
|
|
|
# for details.
|
|
|
|
#
|
|
|
|
# The env var JAX_ENABLE_TPU_XDIST must be set for this hook to have an
|
|
|
|
# effect. We do this to minimize any effect on non-TPU tests, and as a pointer
|
|
|
|
# in test code to this "magic" hook. TPU tests should not specify more xdist
|
|
|
|
# workers than the number of TPU chips.
|
|
|
|
def pytest_collection() -> None:
|
|
|
|
if not os.environ.get("JAX_ENABLE_TPU_XDIST", None):
|
|
|
|
return
|
|
|
|
# When running as an xdist worker, will be something like "gw0"
|
|
|
|
xdist_worker_name = os.environ.get("PYTEST_XDIST_WORKER", "")
|
|
|
|
if not xdist_worker_name.startswith("gw"):
|
|
|
|
return
|
|
|
|
xdist_worker_number = int(xdist_worker_name[len("gw"):])
|
|
|
|
os.environ.setdefault("TPU_VISIBLE_CHIPS", str(xdist_worker_number))
|
|
|
|
os.environ.setdefault("ALLOW_MULTIPLE_LIBTPU_LOAD", "true")
|