diff --git a/src/NzbDrone.Common.Test/Http/HttpUriFixture.cs b/src/NzbDrone.Common.Test/Http/HttpUriFixture.cs new file mode 100644 index 000000000..09cda2be7 --- /dev/null +++ b/src/NzbDrone.Common.Test/Http/HttpUriFixture.cs @@ -0,0 +1,29 @@ +using FluentAssertions; +using NUnit.Framework; +using NzbDrone.Common.Http; +using NzbDrone.Test.Common; + +namespace NzbDrone.Common.Test.Http +{ + public class HttpUriFixture : TestBase + { + private HttpUri GivenHttpUri(string basePath) + { + return new HttpUri("http", "localhost", 8989, basePath, null, null); + } + + [TestCase("", "", "")] + [TestCase("base", "", "/base")] + [TestCase("/base", "", "/base")] + [TestCase("", "relative", "/relative")] + [TestCase("", "/relative", "/relative")] + [TestCase("base", "relative", "/base/relative")] + [TestCase("base", "/relative", "/base/relative")] + [TestCase("/base", "relative", "/base/relative")] + [TestCase("/base", "/relative", "/base/relative")] + public void should_combine_base_path_and_relative_path(string basePath, string relativePath, string expected) + { + GivenHttpUri(basePath).CombinePath(relativePath).Path.Should().Be(expected); + } + } +} diff --git a/src/NzbDrone.Common.Test/NzbDrone.Common.Test.csproj b/src/NzbDrone.Common.Test/NzbDrone.Common.Test.csproj index 338a9e926..84892c6b1 100644 --- a/src/NzbDrone.Common.Test/NzbDrone.Common.Test.csproj +++ b/src/NzbDrone.Common.Test/NzbDrone.Common.Test.csproj @@ -83,6 +83,7 @@ + diff --git a/src/NzbDrone.Common/Http/HttpUri.cs b/src/NzbDrone.Common/Http/HttpUri.cs index c8c83de66..05d12e7d8 100644 --- a/src/NzbDrone.Common/Http/HttpUri.cs +++ b/src/NzbDrone.Common/Http/HttpUri.cs @@ -144,23 +144,12 @@ private static string CombinePath(string basePath, string relativePath) return basePath; } - var newPath = "/" + relativePath.TrimStart('/'); - - if (basePath != null && !relativePath.StartsWith("/")) + if (basePath.IsNullOrWhiteSpace()) { - var baseSlashIndex = basePath.LastIndexOf('/'); - - if (baseSlashIndex == basePath.Length - 1) - { - newPath = basePath.TrimEnd('/') + newPath; - } - else if (baseSlashIndex != 0) - { - newPath = basePath.Substring(0, baseSlashIndex) + newPath; - } + return "/" + relativePath.TrimStart('/'); } - return newPath; + return basePath.TrimEnd("/") + "/" + relativePath.TrimStart('/'); } public HttpUri SetQuery(string query) @@ -199,7 +188,6 @@ public HttpUri AddQueryParams(IEnumerable> queryPar return SetQuery(builder.ToString()); } - public override int GetHashCode() { return _uri.GetHashCode();