Encountered interesting problem after migrating to SQL Server 2017.
Absolute path test
backup database master to disk = 'C:\Temp\1\2\3\master.bak'
Backup is created in C:\Temp\1\2\3\ as expected.
Relative path test #1
backup database master to disk = 'C:\Temp\1\2\3\..\master.bak'
Backup is created in C:\Temp\
Expected: C:\Temp\1\2\
Relative path test #2
backup database master to disk = 'C:\Temp\11\22\33\..\master.bak'
backup database master to disk = 'C:\Temp\111\222\333\..\master.bak'
backup database master to disk = 'C:\Temp\bin\bin\bin\..\master.bak'
Backups are created in folders C:\Temp\11\, C:\Temp\111\, C:\Temp\bin\
Expected: C:\Temp\11\22\, C:\Temp\111\222\ and C:\Temp\bin\bin\ respectively.
Relative path test #3
backup database master to disk = 'C:\Temp\Folder1\Folder2\Folder3\..\master.bak'
backup database master to disk = 'C:\Temp\1111\2222\3333\..\master.bak'
Backups are created in folders C:\Temp\Folder1\Folder2 and C:\Temp\1111\2222 respectively as expected.
As you can see, all relative paths have the same depth, but depending on folder names lengths the backup file lands on different levels. I wasn't able to replicate this issue with SQL Server 2014. I was able to replicate this issue both in SQL Server 2017 RTM and RTM-CU2.
OS: Windows Server 2016. Paths are resolved correctly when pasted to Windows Explorer.
How do I make relative paths work when they contains short (under 4 characters) folder names?