-
Notifications
You must be signed in to change notification settings - Fork 305
Expand file tree
/
Copy pathDbaseReaderTests.cs
More file actions
67 lines (57 loc) · 2.22 KB
/
DbaseReaderTests.cs
File metadata and controls
67 lines (57 loc) · 2.22 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
using System;
using System.Collections.Generic;
using System.Linq;
using System.IO;
using System.Text;
using NUnit.Framework;
using SharpMap.Data.Providers;
namespace UnitTests.Data.Providers
{
[NUnit.Framework.TestFixture]
public class DbaseReaderTests
{
[OneTimeSetUp]
public void OneTimeSetUp()
{
GeoAPI.GeometryServiceProvider.Instance = new NetTopologySuite.NtsGeometryServices();
}
private int GetNumberOfRecords(DbaseReader reader)
{
var numberOfRecordsField = typeof(DbaseReader).GetField("_numberOfRecords", System.Reflection.BindingFlags.NonPublic | System.Reflection.BindingFlags.Instance);
return (int)numberOfRecordsField.GetValue(reader);
}
[NUnit.Framework.Test()]
public void TestDbaseReader()
{
using (DbaseReader reader = new DbaseReader(TestUtility.GetPathToTestFile("SPATIAL_F_SKARVMUFF.dbf")))
{
reader.Open();
int numberOfRecords = GetNumberOfRecords(reader);
// read entire file
for (uint rowid = 0; rowid < numberOfRecords; rowid++)
{
var values = reader.GetValues(rowid);
}
}
}
[NUnit.Framework.Test()]
public void TestDbaseBinaryTree()
{
using (DbaseReader reader = new DbaseReader(TestUtility.GetPathToTestFile("SPATIAL_F_SKARVMUFF.dbf")))
{
reader.Open();
int numberOfRecords = GetNumberOfRecords(reader);
// Create index on OBJECTNO column
var indexOBJECTNO = reader.CreateDbfIndex<int>(0);
// Test if index contains all records
Assert.AreEqual(numberOfRecords, indexOBJECTNO.InOrder.Count());
// Test searching for all records individually
for (uint rowid = 0; rowid < numberOfRecords; rowid++)
{
int value = (int)reader.GetValues(rowid)[1];
Assert.AreEqual(1, indexOBJECTNO.Find(value).Count());
}
}
}
}
}