Newer
Older
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
// Mantid Repository : https://github.com/mantidproject/mantid
//
// Copyright © 2018 ISIS Rutherford Appleton Laboratory UKRI,
// NScD Oak Ridge National Laboratory, European Spallation Source,
// Institut Laue - Langevin & CSNS, Institute of High Energy Physics, CAS
// SPDX - License - Identifier: GPL - 3.0 +
#pragma once
#include "MantidAPI/FileFinder.h"
#include "MantidNexus/NexusHDF5Descriptor.h"
#include <cstddef> // std::size_t
#include <cxxtest/TestSuite.h>
class NexusHDF5DescriptorTest : public CxxTest::TestSuite {
public:
// test get functions getFilename and getAllEntries
void test_nexus_hdf5_descriptor_get() {
const std::string filename =
Mantid::API::FileFinder::Instance().getFullPath("EQSANS_89157.nxs.h5");
Mantid::NeXus::NexusHDF5Descriptor nexusHDF5Descriptor(filename);
TS_ASSERT_EQUALS(filename, nexusHDF5Descriptor.getFilename());
const std::map<std::string, std::set<std::string>> &allEntries =
nexusHDF5Descriptor.getAllEntries();
TS_ASSERT_EQUALS(allEntries.size(), 12);
// confirms existence of groupClass key and expectedSize for value set
auto lf_TestSet = [&](const std::string &groupClass,
const std::size_t expectedSize) -> std::size_t {
auto itClass = allEntries.find(groupClass);
TS_ASSERT_DIFFERS(itClass, allEntries.end());
TS_ASSERT_EQUALS(itClass->second.size(), expectedSize);
return expectedSize;
};
std::size_t nEntries = 0;
nEntries += lf_TestSet("NXcollection", 39);
nEntries += lf_TestSet("NXdetector", 48);
nEntries += lf_TestSet("NXdisk_chopper", 4);
nEntries += lf_TestSet("NXentry", 1);
nEntries += lf_TestSet("NXevent_data", 48);
nEntries += lf_TestSet("NXinstrument", 1);
nEntries += lf_TestSet("NXlog", 204);
nEntries += lf_TestSet("NXmonitor", 3);
nEntries += lf_TestSet("NXnote", 1);
nEntries += lf_TestSet("NXsample", 1);
nEntries += lf_TestSet("NXuser", 6);
nEntries += lf_TestSet("SDS", 2567);
TS_ASSERT_EQUALS(nEntries, 2923);
}
};