|
40 | 40 | funcs{end+1} = @test_has_feature;
|
41 | 41 | funcs{end+1} = @test_has_reference;
|
42 | 42 | funcs{end+1} = @test_compare;
|
| 43 | + funcs{end+1} = @test_filter_source; |
43 | 44 | end
|
44 | 45 |
|
45 | 46 | %% Test: Add sources by entity and id
|
|
652 | 653 | assert(t2.compare(t1) > 0);
|
653 | 654 | assert(t1.compare(t3) ~= 0);
|
654 | 655 | end
|
| 656 | + |
| 657 | +%% Test: filter sources |
| 658 | +function [] = test_filter_source( varargin ) |
| 659 | + filterName = 'filterMe'; |
| 660 | + filterType = 'filterType'; |
| 661 | + f = nix.File(fullfile(pwd, 'tests', 'testRW.h5'), nix.FileMode.Overwrite); |
| 662 | + b = f.create_block('testBlock', 'nixBlock'); |
| 663 | + t = b.create_tag('testTag', 'nixTag', [1 2 3]); |
| 664 | + s = b.create_source(filterName, 'nixSource'); |
| 665 | + t.add_source(s); |
| 666 | + filterID = s.id; |
| 667 | + s = b.create_source('testSource1', filterType); |
| 668 | + t.add_source(s); |
| 669 | + filterIDs = {filterID, s.id}; |
| 670 | + s = b.create_source('testSource2', filterType); |
| 671 | + t.add_source(s); |
| 672 | + |
| 673 | + % test empty id filter |
| 674 | + assert(isempty(f.blocks{1}.tags{1}.filter_sources(nix.Filter.id, 'IdoNotExist'))); |
| 675 | + |
| 676 | + % test nix.Filter.accept_all |
| 677 | + filtered = f.blocks{1}.tags{1}.filter_sources(nix.Filter.accept_all, ''); |
| 678 | + assert(size(filtered, 1) == 3); |
| 679 | + |
| 680 | + % test nix.Filter.id |
| 681 | + filtered = f.blocks{1}.tags{1}.filter_sources(nix.Filter.id, filterID); |
| 682 | + assert(size(filtered, 1) == 1); |
| 683 | + assert(strcmp(filtered{1}.id, filterID)); |
| 684 | + |
| 685 | + % test nix.Filter.ids |
| 686 | + filtered = f.blocks{1}.tags{1}.filter_sources(nix.Filter.ids, filterIDs); |
| 687 | + assert(size(filtered, 1) == 2); |
| 688 | + assert(strcmp(filtered{1}.id, filterIDs{1}) || strcmp(filtered{1}.id, filterIDs{2})); |
| 689 | + |
| 690 | + % test nix.Filter.name |
| 691 | + filtered = f.blocks{1}.tags{1}.filter_sources(nix.Filter.name, filterName); |
| 692 | + assert(size(filtered, 1) == 1); |
| 693 | + assert(strcmp(filtered{1}.name, filterName)); |
| 694 | + |
| 695 | + % test nix.Filter.type |
| 696 | + filtered = f.blocks{1}.tags{1}.filter_sources(nix.Filter.type, filterType); |
| 697 | + assert(size(filtered, 1) == 2); |
| 698 | + |
| 699 | + % test nix.Filter.metadata |
| 700 | + mainName = 'testSubSection'; |
| 701 | + mainSource = b.create_source(mainName, 'nixSource'); |
| 702 | + t.add_source(mainSource); |
| 703 | + subName = 'testSubSection1'; |
| 704 | + s = f.create_section(subName, 'nixSection'); |
| 705 | + mainSource.set_metadata(s); |
| 706 | + subID = s.id; |
| 707 | + |
| 708 | + assert(isempty(f.blocks{1}.tags{1}.filter_sources(nix.Filter.metadata, 'Do not exist'))); |
| 709 | + filtered = f.blocks{1}.tags{1}.filter_sources(nix.Filter.metadata, subID); |
| 710 | + assert(size(filtered, 1) == 1); |
| 711 | + assert(strcmp(filtered{1}.name, mainName)); |
| 712 | + |
| 713 | + % test nix.Filter.source |
| 714 | + mainName = 'testSubSource'; |
| 715 | + main = b.create_source(mainName, 'nixSource'); |
| 716 | + t.add_source(main); |
| 717 | + mainID = main.id; |
| 718 | + subName = 'testSubSource1'; |
| 719 | + s = main.create_source(subName, 'nixSource'); |
| 720 | + subID = s.id; |
| 721 | + |
| 722 | + assert(isempty(f.blocks{1}.tags{1}.filter_sources(nix.Filter.source, 'Do not exist'))); |
| 723 | + filtered = f.blocks{1}.tags{1}.filter_sources(nix.Filter.source, subName); |
| 724 | + assert(size(filtered, 1) == 1); |
| 725 | + assert(strcmp(filtered{1}.id, mainID)); |
| 726 | + |
| 727 | + filtered = f.blocks{1}.tags{1}.filter_sources(nix.Filter.source, subID); |
| 728 | + assert(size(filtered, 1) == 1); |
| 729 | + assert(strcmp(filtered{1}.name, mainName)); |
| 730 | +end |
0 commit comments