|
26 | 26 | funcs{end+1} = @test_referring_tags;
|
27 | 27 | funcs{end+1} = @test_referring_multi_tags;
|
28 | 28 | funcs{end+1} = @test_compare;
|
| 29 | + funcs{end+1} = @test_filter_source; |
29 | 30 | end
|
30 | 31 |
|
31 | 32 | %% Test: fetch sources
|
|
298 | 299 | assert(s2.compare(s1) > 0);
|
299 | 300 | assert(s1.compare(s3) ~= 0);
|
300 | 301 | end
|
| 302 | + |
| 303 | +%% Test: filter sources |
| 304 | +function [] = test_filter_source( varargin ) |
| 305 | + filterName = 'filterMe'; |
| 306 | + filterType = 'filterType'; |
| 307 | + f = nix.File(fullfile(pwd, 'tests', 'testRW.h5'), nix.FileMode.Overwrite); |
| 308 | + b = f.create_block('testBlock', 'nixBlock'); |
| 309 | + ms = b.create_source('testSource', 'nixSource'); |
| 310 | + s = ms.create_source(filterName, 'nixSource'); |
| 311 | + filterID = s.id; |
| 312 | + s = ms.create_source('testSource1', filterType); |
| 313 | + filterIDs = {filterID, s.id}; |
| 314 | + s = ms.create_source('testSource2', filterType); |
| 315 | + |
| 316 | + % test empty id filter |
| 317 | + assert(isempty(f.blocks{1}.sources{1}.filter_sources(nix.Filter.id, 'IdoNotExist'))); |
| 318 | + |
| 319 | + % test nix.Filter.accept_all |
| 320 | + filtered = f.blocks{1}.sources{1}.filter_sources(nix.Filter.accept_all, ''); |
| 321 | + assert(size(filtered, 1) == 3); |
| 322 | + |
| 323 | + % test nix.Filter.id |
| 324 | + filtered = f.blocks{1}.sources{1}.filter_sources(nix.Filter.id, filterID); |
| 325 | + assert(size(filtered, 1) == 1); |
| 326 | + assert(strcmp(filtered{1}.id, filterID)); |
| 327 | + |
| 328 | + % test nix.Filter.ids |
| 329 | + filtered = f.blocks{1}.sources{1}.filter_sources(nix.Filter.ids, filterIDs); |
| 330 | + assert(size(filtered, 1) == 2); |
| 331 | + assert(strcmp(filtered{1}.id, filterIDs{1}) || strcmp(filtered{1}.id, filterIDs{2})); |
| 332 | + |
| 333 | + % test nix.Filter.name |
| 334 | + filtered = f.blocks{1}.sources{1}.filter_sources(nix.Filter.name, filterName); |
| 335 | + assert(size(filtered, 1) == 1); |
| 336 | + assert(strcmp(filtered{1}.name, filterName)); |
| 337 | + |
| 338 | + % test nix.Filter.type |
| 339 | + filtered = f.blocks{1}.sources{1}.filter_sources(nix.Filter.type, filterType); |
| 340 | + assert(size(filtered, 1) == 2); |
| 341 | + |
| 342 | + % test nix.Filter.metadata |
| 343 | + mainName = 'testSubSection'; |
| 344 | + mainSource = ms.create_source(mainName, 'nixSource'); |
| 345 | + subName = 'testSubSection1'; |
| 346 | + s = f.create_section(subName, 'nixSection'); |
| 347 | + mainSource.set_metadata(s); |
| 348 | + subID = s.id; |
| 349 | + |
| 350 | + assert(isempty(f.blocks{1}.sources{1}.filter_sources(nix.Filter.metadata, 'Do not exist'))); |
| 351 | + filtered = f.blocks{1}.sources{1}.filter_sources(nix.Filter.metadata, subID); |
| 352 | + assert(size(filtered, 1) == 1); |
| 353 | + assert(strcmp(filtered{1}.name, mainName)); |
| 354 | + |
| 355 | + % test nix.Filter.source |
| 356 | + mainName = 'testSubSource'; |
| 357 | + main = ms.create_source(mainName, 'nixSource'); |
| 358 | + mainID = main.id; |
| 359 | + subName = 'testSubSource1'; |
| 360 | + s = main.create_source(subName, 'nixSource'); |
| 361 | + subID = s.id; |
| 362 | + |
| 363 | + assert(isempty(f.blocks{1}.sources{1}.filter_sources(nix.Filter.source, 'Do not exist'))); |
| 364 | + filtered = f.blocks{1}.sources{1}.filter_sources(nix.Filter.source, subName); |
| 365 | + assert(size(filtered, 1) == 1); |
| 366 | + assert(strcmp(filtered{1}.id, mainID)); |
| 367 | + |
| 368 | + filtered = f.blocks{1}.sources{1}.filter_sources(nix.Filter.source, subID); |
| 369 | + assert(size(filtered, 1) == 1); |
| 370 | + assert(strcmp(filtered{1}.name, mainName)); |
| 371 | +end |
0 commit comments