Пример #1
0
def test_create_unknown_image_raises_docker_error_no_such_image(profile):
    profile.docker_image = 'unknown_image:tag'

    with pytest.raises(DockerError) as excinfo:
        create(profile.name)

    error = str(excinfo.value)
    # Error message depends on whether Docker Swarm is used
    assert any(("No such image" in error, "not found" in error))
    assert 'unknown_image:tag' in error
Пример #2
0
def test_create_unknown_image_raises_docker_error_no_such_image(
        profile_unknown_image, config):
    utils._DOCKER_CLIENTS = {}  # clear clients cache
    config.DOCKER_MAX_TOTAL_RETRIES = 0

    with pytest.raises(DockerError) as excinfo:
        create(profile_unknown_image.name)

    error = str(excinfo.value)
    # Error message depends on whether Docker Swarm is used
    assert any(("No such image" in error, "not exist" in error))
    assert 'unknown_image' in error
Пример #3
0
def test_destroy_not_started(profile, docker_client):
    sandbox = create(profile.name)
    assert docker_client.inspect_container(sandbox)

    destroy(sandbox)

    with pytest.raises(docker.errors.NotFound):
        docker_client.inspect_container(sandbox)
Пример #4
0
def test_create_start_destroy_with_context_manager(profile, docker_client):
    with create(profile.name, 'cat') as sandbox:
        result = start(sandbox)
        assert result['stdout'] == b''

        result = start(sandbox, stdin=b'stdin data')
        assert result['stdout'] == b'stdin data'

    with pytest.raises(docker.errors.NotFound):
        docker_client.inspect_container(sandbox)
Пример #5
0
def test_destroy_exited(profile, docker_client):
    sandbox = create(profile.name, 'true')
    result = start(sandbox)
    assert result['exit_code'] == 0
    assert docker_client.inspect_container(sandbox)

    destroy(sandbox)

    with pytest.raises(docker.errors.NotFound):
        docker_client.inspect_container(sandbox)
Пример #6
0
def test_destroy_running(profile, docker_client):
    sandbox = create(profile.name, 'sleep 10', limits={'realtime': 1})
    result = start(sandbox)
    assert result['timeout'] is True
    container_info = docker_client.inspect_container(sandbox)
    assert container_info['State']['Running'] is True

    destroy(sandbox)

    with pytest.raises(docker.errors.NotFound):
        docker_client.inspect_container(sandbox)
Пример #7
0
def test_destroy_running(profile, docker_client):
    sandbox = create(profile.name, 'sleep 10', limits={'realtime': 1})
    result = start(sandbox)
    assert result['timeout'] is True
    container = docker_client.containers.get(sandbox.container.id)
    assert container.status == 'running'

    destroy(sandbox)

    with pytest.raises(docker.errors.NotFound):
        docker_client.containers.get(sandbox.container.id)
Пример #8
0
def test_create(profile, docker_client):
    test_containers = docker_client.containers(
        filters={'name': 'epicbox-test-'}, all=True)
    assert test_containers == []

    sandbox = create(profile.name, 'true')

    container = docker_client.inspect_container(sandbox)
    assert container['Name'].startswith('/epicbox-test-')
    assert container['State']['Status'] == 'created'
    assert 'true' in container['Args']
    assert sandbox['RealtimeLimit'] == 5
Пример #9
0
def test_create(profile, docker_client):
    test_containers = docker_client.containers.list(
        filters={'name': 'epicbox-test-'}, all=True)
    assert test_containers == []

    sandbox = create(profile.name, 'true')

    container = docker_client.containers.get(sandbox.container.id)
    assert container.name.startswith('epicbox-test-')
    assert container.status == 'created'
    assert 'true' in container.attrs['Args']
    assert sandbox.realtime_limit == 5
Пример #10
0
def test_start_with_stdin_data_str(profile):
    sandbox = create(profile.name, 'cat')

    result = start(sandbox, stdin="stdin data\n")

    expected_result = {
        'exit_code': 0,
        'stdout': b'stdin data\n',
        'stderr': b'',
        'duration': ANY,
        'timeout': False,
        'oom_killed': False,
    }
    assert result == expected_result
    assert result['duration'] > 0
Пример #11
0
def test_start_no_stdin_data(profile):
    command = 'echo "stdout data" && echo "stderr data" >&2'
    sandbox = create(profile.name, command)

    result = start(sandbox)

    expected_result = {
        'exit_code': 0,
        'stdout': b'stdout data\n',
        'stderr': b'stderr data\n',
        'duration': ANY,
        'timeout': False,
        'oom_killed': False,
    }
    assert result == expected_result
    assert result['duration'] > 0
Пример #12
0
def test_start_same_sandbox_multiple_times(profile):
    sandbox = create(profile.name, 'cat', limits={'cputime': 20})
    expected_result = {
        'exit_code': 0,
        'stdout': b'',
        'stderr': b'',
        'duration': ANY,
        'timeout': False,
        'oom_killed': False,
    }

    result = start(sandbox)
    assert result == expected_result

    result = start(sandbox, stdin=b'stdin data')
    assert result == dict(expected_result, stdout=b'stdin data')

    long_data = b'stdin long data' + b'a b c d e\n' * 100000
    result = start(sandbox, stdin=long_data)
    assert result == dict(expected_result, stdout=long_data)

    result = start(sandbox)
    assert result == expected_result