blob: 6d730cbe75e63206c4a128f7f0da41019724f4d4 [file] [log] [blame]
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you 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 os
from concurrent.futures import ThreadPoolExecutor
from typing import Dict, Optional
from unittest import mock
import pytest
from pyiceberg.utils.concurrent import ExecutorFactory
EMPTY_ENV: Dict[str, Optional[str]] = {}
VALID_ENV = {"PYICEBERG_MAX_WORKERS": "5"}
INVALID_ENV = {"PYICEBERG_MAX_WORKERS": "invalid"}
def test_create_reused() -> None:
first = ExecutorFactory.get_or_create()
second = ExecutorFactory.get_or_create()
assert isinstance(first, ThreadPoolExecutor)
assert first is second
@mock.patch.dict(os.environ, EMPTY_ENV)
def test_max_workers_none() -> None:
assert ExecutorFactory.max_workers() is None
@mock.patch.dict(os.environ, VALID_ENV)
def test_max_workers() -> None:
assert ExecutorFactory.max_workers() == 5
@mock.patch.dict(os.environ, INVALID_ENV)
def test_max_workers_invalid() -> None:
with pytest.raises(ValueError):
ExecutorFactory.max_workers()