|
1 | 1 | import gzip
|
2 | 2 | import io
|
| 3 | +import shutil |
3 | 4 |
|
4 | 5 | import docker
|
5 | 6 | from docker import auth
|
| 7 | +from docker.api.build import process_dockerfile |
6 | 8 |
|
7 |
| -from .api_test import BaseAPIClientTest, fake_request, url_prefix |
8 | 9 | import pytest
|
9 | 10 |
|
| 11 | +from ..helpers import make_tree |
| 12 | +from .api_test import BaseAPIClientTest, fake_request, url_prefix |
| 13 | + |
10 | 14 |
|
11 | 15 | class BuildTest(BaseAPIClientTest):
|
12 | 16 | def test_build_container(self):
|
@@ -161,3 +165,61 @@ def test_set_auth_headers_with_dict_and_no_auth_configs(self):
|
161 | 165 |
|
162 | 166 | self.client._set_auth_headers(headers)
|
163 | 167 | assert headers == expected_headers
|
| 168 | + |
| 169 | + @pytest.mark.skipif( |
| 170 | + not docker.constants.IS_WINDOWS_PLATFORM, |
| 171 | + reason='Windows-specific syntax') |
| 172 | + def test_process_dockerfile_win_longpath_prefix(self): |
| 173 | + dirs = [ |
| 174 | + 'foo', 'foo/bar', 'baz', |
| 175 | + ] |
| 176 | + |
| 177 | + files = [ |
| 178 | + 'Dockerfile', 'foo/Dockerfile.foo', 'foo/bar/Dockerfile.bar', |
| 179 | + 'baz/Dockerfile.baz', |
| 180 | + ] |
| 181 | + |
| 182 | + base = make_tree(dirs, files) |
| 183 | + self.addCleanup(shutil.rmtree, base) |
| 184 | + |
| 185 | + def pre(path): |
| 186 | + return docker.constants.WINDOWS_LONGPATH_PREFIX + path |
| 187 | + |
| 188 | + assert process_dockerfile(None, pre(base)) == (None, None) |
| 189 | + assert process_dockerfile('Dockerfile', pre(base)) == ( |
| 190 | + 'Dockerfile', None |
| 191 | + ) |
| 192 | + assert process_dockerfile('foo/Dockerfile.foo', pre(base)) == ( |
| 193 | + 'foo/Dockerfile.foo', None |
| 194 | + ) |
| 195 | + assert process_dockerfile( |
| 196 | + '../Dockerfile', pre(base + '\\foo') |
| 197 | + )[1] is not None |
| 198 | + assert process_dockerfile( |
| 199 | + '../baz/Dockerfile.baz', pre(base + '/baz') |
| 200 | + ) == ('../baz/Dockerfile.baz', None) |
| 201 | + |
| 202 | + def test_process_dockerfile(self): |
| 203 | + dirs = [ |
| 204 | + 'foo', 'foo/bar', 'baz', |
| 205 | + ] |
| 206 | + |
| 207 | + files = [ |
| 208 | + 'Dockerfile', 'foo/Dockerfile.foo', 'foo/bar/Dockerfile.bar', |
| 209 | + 'baz/Dockerfile.baz', |
| 210 | + ] |
| 211 | + |
| 212 | + base = make_tree(dirs, files) |
| 213 | + self.addCleanup(shutil.rmtree, base) |
| 214 | + |
| 215 | + assert process_dockerfile(None, base) == (None, None) |
| 216 | + assert process_dockerfile('Dockerfile', base) == ('Dockerfile', None) |
| 217 | + assert process_dockerfile('foo/Dockerfile.foo', base) == ( |
| 218 | + 'foo/Dockerfile.foo', None |
| 219 | + ) |
| 220 | + assert process_dockerfile( |
| 221 | + '../Dockerfile', base + '/foo' |
| 222 | + )[1] is not None |
| 223 | + assert process_dockerfile('../baz/Dockerfile.baz', base + '/baz') == ( |
| 224 | + '../baz/Dockerfile.baz', None |
| 225 | + ) |
0 commit comments