aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorJeroen van Rijn <Kelimion@users.noreply.github.com>2025-05-11 15:35:52 +0200
committerJeroen van Rijn <Kelimion@users.noreply.github.com>2025-05-11 15:35:52 +0200
commit30388cada3d2bee633285516344d8d5a88308eb0 (patch)
treeadb48b3c5e50b22d9d4025235058782cd96b9f94 /tests
parentecd0655ba253397de9aabc5b1010f4999d7805e6 (diff)
Fix os2.clean_path on Windows
Diffstat (limited to 'tests')
-rw-r--r--tests/core/os/os2/path.odin85
-rw-r--r--tests/core/os/os2/process.odin1
2 files changed, 49 insertions, 37 deletions
diff --git a/tests/core/os/os2/path.odin b/tests/core/os/os2/path.odin
index 2cf1f1f1c..7b1cb0146 100644
--- a/tests/core/os/os2/path.odin
+++ b/tests/core/os/os2/path.odin
@@ -36,47 +36,58 @@ posix_to_dos_path :: proc(path: string) -> string {
@(test)
test_clean_path :: proc(t: ^testing.T) {
Test_Case :: struct{
- path: string,
+ path: string,
expected: string,
}
- test_cases := [?]Test_Case {
- {`../../foo/../../`, `../../..`},
- {`../../foo/..`, `../..`},
- {`../../foo`, `../../foo`},
- {`../..`, `../..`},
- {`.././foo`, `../foo`},
- {`..`, `..`},
- {`.`, `.`},
- {`.foo`, `.foo`},
- {`/../../foo/../../`, `/`},
- {`/../`, `/`},
- {`/..`, `/`},
- {`/`, `/`},
- {`//home/foo/bar/../../`, `/home`},
- {`/a/../..`, `/`},
- {`/a/../`, `/`},
- {`/a/あ`, `/a/あ`},
- {`/a/あ/..`, `/a`},
- {`/あ/a/..`, `/あ`},
- {`/あ/a/../あ`, `/あ/あ`},
- {`/home/../`, `/`},
- {`/home/..`, `/`},
- {`/home/foo/../../usr`, `/usr`},
- {`/home/foo/../..`, `/`},
- {`/home/foo/../`, `/home`},
- {``, `.`},
- {`a/..`, `.`},
- {`a`, `a`},
- {`abc//.//../foo`, `foo`},
- {`foo`, `foo`},
- {`home/foo/bar/../../`, `home`},
- }
-
when ODIN_OS == .Windows {
- for &tc in test_cases {
- tc.path = posix_to_dos_path(tc.path)
- tc.expected = posix_to_dos_path(tc.expected)
+ test_cases := [?]Test_Case {
+ {`W:/odin\examples\demo/demo.odin`, `W:\odin\examples\demo\demo.odin`},
+ {`\\server\share\path\file.ext`, `\\server\share\path\file.ext`},
+ {`//server\share/path\file.ext`, `\\server\share\path\file.ext`},
+ {`/\192.168.0.10\share/path\file.ext`, `\\192.168.0.10\share\path\file.ext`},
+ {`\\?\C:/Users/Foo/path\file.ext`, `\\?\C:\Users\Foo\path\file.ext`},
+ {`\\?\\localhost\share\file.ext`, `\\?\\localhost\share\file.ext`},
+ {`//?\/192.168.0.10\share\file.ext`, `\\?\\192.168.0.10\share\file.ext`},
+ {`\\.\PhysicalDrive3`, `\\.\PhysicalDrive3`},
+ {`/\./PhysicalDrive3`, `\\.\PhysicalDrive3`},
+ {`C:\a\..\..`, `C:\`},
+ {`C:\a\..`, `C:\`},
+ {`C:\あ/a/..`, `C:\あ`},
+ {`C:\あ/a/../あ`, `C:\あ\あ`},
+ }
+ } else {
+ test_cases := [?]Test_Case {
+ {`../../foo/../../`, `../../..`},
+ {`../../foo/..`, `../..`},
+ {`../../foo`, `../../foo`},
+ {`../..`, `../..`},
+ {`.././foo`, `../foo`},
+ {`..`, `..`},
+ {`.`, `.`},
+ {`.foo`, `.foo`},
+ {`/../../foo/../../`, `/`},
+ {`/../`, `/`},
+ {`/..`, `/`},
+ {`/`, `/`},
+ {`//home/foo/bar/../../`, `/home`},
+ {`/a/../..`, `/`},
+ {`/a/../`, `/`},
+ {`/a/あ`, `/a/あ`},
+ {`/a/あ/..`, `/a`},
+ {`/あ/a/..`, `/あ`},
+ {`/あ/a/../あ`, `/あ/あ`},
+ {`/home/../`, `/`},
+ {`/home/..`, `/`},
+ {`/home/foo/../../usr`, `/usr`},
+ {`/home/foo/../..`, `/`},
+ {`/home/foo/../`, `/home`},
+ {``, `.`},
+ {`a/..`, `.`},
+ {`a`, `a`},
+ {`abc//.//../foo`, `foo`},
+ {`foo`, `foo`},
+ {`home/foo/bar/../../`, `home`},
}
}
diff --git a/tests/core/os/os2/process.odin b/tests/core/os/os2/process.odin
index d7700d201..c530b4c79 100644
--- a/tests/core/os/os2/process.odin
+++ b/tests/core/os/os2/process.odin
@@ -1,3 +1,4 @@
+#+build !windows
package tests_core_os_os2
import os "core:os/os2"