15d911c86b
modified: Core.Tests/Core.Tests.csproj modified: Core.Tests/Parsers/FluxnetSiteCsvParserTests.cs new file: Core.Tests/Remote/PiscalSshClientTests.cs modified: Core/Core.csproj modified: Core/DAL/LeafWebContext.cs modified: Core/DAL/LeafWebInitializer.cs modified: Core/Models/LeafInput.cs new file: Core/Models/PhotosynthesisType.cs new file: Core/Remote/IPiscalClient.cs Get Piscal
69 lines
2.0 KiB
C#
69 lines
2.0 KiB
C#
using System;
|
|
using System.IO;
|
|
using System.Linq;
|
|
using System.Text.RegularExpressions;
|
|
using LeafWeb.Core.Parsers;
|
|
using LeafWeb.Core.Utility;
|
|
using NUnit.Framework;
|
|
|
|
namespace LeafWeb.Core.Tests.Parsers
|
|
{
|
|
[TestFixture]
|
|
public class FluxnetSiteCsvParserTests
|
|
{
|
|
private const string ContentDirectory = @"Parsers\FluxnetSiteData\";
|
|
|
|
[Test]
|
|
public void Parse_Valid()
|
|
{
|
|
var fileInfo = FileUtility.GetContentFile(ContentDirectory, "fluxnet_site_list_all_October2015_with_joins.csv");
|
|
var parser = new FluxnetSiteCsvParser(fileInfo);
|
|
foreach (var fns in parser.Parse())
|
|
{
|
|
Console.WriteLine($"{fns.FluxnetId} / {fns.SiteName}");
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void Parse_Find_Misencoded_Characters()
|
|
{
|
|
var fileInfo = FileUtility.GetContentFile(ContentDirectory, "fluxnet_site_list_all_October2015_with_joins.csv");
|
|
var parser = new FluxnetSiteCsvParser(fileInfo);
|
|
foreach (var fns in parser.Parse().Where(f => Regex.IsMatch(f.SiteName, @"[^\x00-\x7F]") || f.SiteName.Contains("?")))
|
|
{
|
|
Console.WriteLine($"{fns.FluxnetId} / {fns.SiteName}");
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void Parse_Find_Misencoded_Characters_test()
|
|
{
|
|
var fileInfo = new FileInfo(@"C:\Users\poprhythm\Documents\code\LeafWeb\Core\DAL\InitialData\fluxnet_site_list_all_October2015_with_joins_corrected.csv");
|
|
var parser = new FluxnetSiteCsvParser(fileInfo);
|
|
foreach (var fns in parser.Parse().Where(f => Regex.IsMatch(f.SiteName, @"[^\x00-\x7F]") || f.SiteName.Contains("?")))
|
|
{
|
|
Console.WriteLine($"{fns.FluxnetId} / {fns.SiteName}");
|
|
}
|
|
}
|
|
|
|
[Test]
|
|
public void Parse_Find_Duplicate_Ids()
|
|
{
|
|
var fileInfo = FileUtility.GetContentFile(ContentDirectory, "fluxnet_site_list_all_October2015_with_joins.csv");
|
|
var parser = new FluxnetSiteCsvParser(fileInfo);
|
|
var fluxnetSites = parser.Parse();
|
|
|
|
var dupes =
|
|
from f in fluxnetSites
|
|
group f by f.FluxnetId.ToUpper()
|
|
into g
|
|
where g.Count() > 1
|
|
select g.Key;
|
|
|
|
foreach (var dupe in dupes)
|
|
{
|
|
Console.WriteLine($"{dupe}");
|
|
}
|
|
}
|
|
}
|
|
} |