Merge pull request #5999 from Bond-009/legacyhdhomerun
Add support for legacy HDhomerun DUAl
This commit is contained in:
commit
5acb4e9491
|
@ -74,7 +74,7 @@ namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
|
||||||
{
|
{
|
||||||
var model = await GetModelInfo(info, false, cancellationToken).ConfigureAwait(false);
|
var model = await GetModelInfo(info, false, cancellationToken).ConfigureAwait(false);
|
||||||
|
|
||||||
using var response = await _httpClientFactory.CreateClient(NamedClient.Default).GetAsync(model.LineupURL, HttpCompletionOption.ResponseHeadersRead, cancellationToken).ConfigureAwait(false);
|
using var response = await _httpClientFactory.CreateClient(NamedClient.Default).GetAsync(model.LineupURL ?? model.BaseURL + "/lineup.json", HttpCompletionOption.ResponseHeadersRead, cancellationToken).ConfigureAwait(false);
|
||||||
await using var stream = await response.Content.ReadAsStreamAsync(cancellationToken).ConfigureAwait(false);
|
await using var stream = await response.Content.ReadAsStreamAsync(cancellationToken).ConfigureAwait(false);
|
||||||
var lineup = await JsonSerializer.DeserializeAsync<List<Channels>>(stream, _jsonOptions, cancellationToken)
|
var lineup = await JsonSerializer.DeserializeAsync<List<Channels>>(stream, _jsonOptions, cancellationToken)
|
||||||
.ConfigureAwait(false) ?? new List<Channels>();
|
.ConfigureAwait(false) ?? new List<Channels>();
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
using System;
|
using System;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Net.Http;
|
using System.Net.Http;
|
||||||
|
using System.Text.Json;
|
||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using AutoFixture;
|
using AutoFixture;
|
||||||
|
@ -15,8 +16,6 @@ namespace Jellyfin.Server.Implementations.Tests.LiveTv
|
||||||
{
|
{
|
||||||
public class HdHomerunHostTests
|
public class HdHomerunHostTests
|
||||||
{
|
{
|
||||||
private const string TestIp = "http://192.168.1.182";
|
|
||||||
|
|
||||||
private readonly Fixture _fixture;
|
private readonly Fixture _fixture;
|
||||||
private readonly HdHomerunHost _hdHomerunHost;
|
private readonly HdHomerunHost _hdHomerunHost;
|
||||||
|
|
||||||
|
@ -30,7 +29,7 @@ namespace Jellyfin.Server.Implementations.Tests.LiveTv
|
||||||
{
|
{
|
||||||
return Task.FromResult(new HttpResponseMessage()
|
return Task.FromResult(new HttpResponseMessage()
|
||||||
{
|
{
|
||||||
Content = new StreamContent(File.OpenRead("Test Data/LiveTv/" + m.RequestUri?.Segments[^1]))
|
Content = new StreamContent(File.OpenRead(Path.Combine("Test Data/LiveTv", m.RequestUri!.Host, m.RequestUri.Segments[^1])))
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -50,7 +49,7 @@ namespace Jellyfin.Server.Implementations.Tests.LiveTv
|
||||||
{
|
{
|
||||||
var host = new TunerHostInfo()
|
var host = new TunerHostInfo()
|
||||||
{
|
{
|
||||||
Url = TestIp
|
Url = "192.168.1.182"
|
||||||
};
|
};
|
||||||
|
|
||||||
var modelInfo = await _hdHomerunHost.GetModelInfo(host, true, CancellationToken.None).ConfigureAwait(false);
|
var modelInfo = await _hdHomerunHost.GetModelInfo(host, true, CancellationToken.None).ConfigureAwait(false);
|
||||||
|
@ -65,6 +64,26 @@ namespace Jellyfin.Server.Implementations.Tests.LiveTv
|
||||||
Assert.Equal("http://192.168.1.182:80/lineup.json", modelInfo.LineupURL);
|
Assert.Equal("http://192.168.1.182:80/lineup.json", modelInfo.LineupURL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
public async Task GetModelInfo_Legacy_Success()
|
||||||
|
{
|
||||||
|
var host = new TunerHostInfo()
|
||||||
|
{
|
||||||
|
Url = "10.10.10.100"
|
||||||
|
};
|
||||||
|
|
||||||
|
var modelInfo = await _hdHomerunHost.GetModelInfo(host, true, CancellationToken.None).ConfigureAwait(false);
|
||||||
|
Assert.Equal("HDHomeRun DUAL", modelInfo.FriendlyName);
|
||||||
|
Assert.Equal("HDHR3-US", modelInfo.ModelNumber);
|
||||||
|
Assert.Equal("hdhomerun3_atsc", modelInfo.FirmwareName);
|
||||||
|
Assert.Equal("20200225", modelInfo.FirmwareVersion);
|
||||||
|
Assert.Equal("10xxxxx5", modelInfo.DeviceID);
|
||||||
|
Assert.Null(modelInfo.DeviceAuth);
|
||||||
|
Assert.Equal(2, modelInfo.TunerCount);
|
||||||
|
Assert.Equal("http://10.10.10.100:80", modelInfo.BaseURL);
|
||||||
|
Assert.Null(modelInfo.LineupURL);
|
||||||
|
}
|
||||||
|
|
||||||
[Fact]
|
[Fact]
|
||||||
public async Task GetModelInfo_EmptyUrl_ArgumentException()
|
public async Task GetModelInfo_EmptyUrl_ArgumentException()
|
||||||
{
|
{
|
||||||
|
@ -81,7 +100,7 @@ namespace Jellyfin.Server.Implementations.Tests.LiveTv
|
||||||
{
|
{
|
||||||
var host = new TunerHostInfo()
|
var host = new TunerHostInfo()
|
||||||
{
|
{
|
||||||
Url = TestIp
|
Url = "192.168.1.182"
|
||||||
};
|
};
|
||||||
|
|
||||||
var channels = await _hdHomerunHost.GetLineup(host, CancellationToken.None).ConfigureAwait(false);
|
var channels = await _hdHomerunHost.GetLineup(host, CancellationToken.None).ConfigureAwait(false);
|
||||||
|
@ -93,12 +112,24 @@ namespace Jellyfin.Server.Implementations.Tests.LiveTv
|
||||||
Assert.Equal("http://192.168.1.111:5004/auto/v4.1", channels[0].URL);
|
Assert.Equal("http://192.168.1.111:5004/auto/v4.1", channels[0].URL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Fact]
|
||||||
|
public async Task GetLineup_Legacy_Success()
|
||||||
|
{
|
||||||
|
var host = new TunerHostInfo()
|
||||||
|
{
|
||||||
|
Url = "10.10.10.100"
|
||||||
|
};
|
||||||
|
|
||||||
|
// Placeholder json is invalid, just need to make sure we can reach it
|
||||||
|
await Assert.ThrowsAsync<JsonException>(() => _hdHomerunHost.GetLineup(host, CancellationToken.None));
|
||||||
|
}
|
||||||
|
|
||||||
[Fact]
|
[Fact]
|
||||||
public async Task GetLineup_ImportFavoritesOnly_Success()
|
public async Task GetLineup_ImportFavoritesOnly_Success()
|
||||||
{
|
{
|
||||||
var host = new TunerHostInfo()
|
var host = new TunerHostInfo()
|
||||||
{
|
{
|
||||||
Url = TestIp,
|
Url = "192.168.1.182",
|
||||||
ImportFavoritesOnly = true
|
ImportFavoritesOnly = true
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -114,9 +145,9 @@ namespace Jellyfin.Server.Implementations.Tests.LiveTv
|
||||||
[Fact]
|
[Fact]
|
||||||
public async Task TryGetTunerHostInfo_Valid_Success()
|
public async Task TryGetTunerHostInfo_Valid_Success()
|
||||||
{
|
{
|
||||||
var host = await _hdHomerunHost.TryGetTunerHostInfo(TestIp, CancellationToken.None).ConfigureAwait(false);
|
var host = await _hdHomerunHost.TryGetTunerHostInfo("192.168.1.182", CancellationToken.None).ConfigureAwait(false);
|
||||||
Assert.Equal(_hdHomerunHost.Type, host.Type);
|
Assert.Equal(_hdHomerunHost.Type, host.Type);
|
||||||
Assert.Equal(TestIp, host.Url);
|
Assert.Equal("192.168.1.182", host.Url);
|
||||||
Assert.Equal("HDHomeRun PRIME", host.FriendlyName);
|
Assert.Equal("HDHomeRun PRIME", host.FriendlyName);
|
||||||
Assert.Equal("FFFFFFFF", host.DeviceId);
|
Assert.Equal("FFFFFFFF", host.DeviceId);
|
||||||
Assert.Equal(3, host.TunerCount);
|
Assert.Equal(3, host.TunerCount);
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
{"FriendlyName":"HDHomeRun DUAL","ModelNumber":"HDHR3-US","Legacy":1,"FirmwareName":"hdhomerun3_atsc","FirmwareVersion":"20200225","DeviceID":"10xxxxx5","TunerCount":2,"BaseURL":"http://10.10.10.100:80"}
|
|
@ -0,0 +1 @@
|
||||||
|
{}
|
Loading…
Reference in New Issue
Block a user