|
42 | 42 | funcs{end+1} = @test_compare;
|
43 | 43 | funcs{end+1} = @test_filter_source;
|
44 | 44 | funcs{end+1} = @test_filter_reference;
|
| 45 | + funcs{end+1} = @test_filter_feature; |
45 | 46 | end
|
46 | 47 |
|
47 | 48 | %% Test: Add sources by entity and id
|
|
803 | 804 | assert(size(filtered, 1) == 1);
|
804 | 805 | assert(strcmp(filtered{1}.name, mainName));
|
805 | 806 | end
|
| 807 | + |
| 808 | +%% Test: filter features |
| 809 | +function [] = test_filter_feature( varargin ) |
| 810 | + f = nix.File(fullfile(pwd, 'tests', 'testRW.h5'), nix.FileMode.Overwrite); |
| 811 | + b = f.create_block('testBlock', 'nixBlock'); |
| 812 | + t = b.create_tag('testTag', 'nixTag', [1 2 3]); |
| 813 | + d = b.create_data_array('testDataArray1', 'nixDataArray', nix.DataType.Double, [1 2]); |
| 814 | + feat = t.add_feature(d, nix.LinkType.Tagged); |
| 815 | + filterID = feat.id; |
| 816 | + d = b.create_data_array('testDataArray2', 'nixDataArray', nix.DataType.Double, [1 2]); |
| 817 | + feat = t.add_feature(d, nix.LinkType.Tagged); |
| 818 | + filterIDs = {filterID, feat.id}; |
| 819 | + |
| 820 | + % test empty id filter |
| 821 | + assert(isempty(f.blocks{1}.tags{1}.filter_features(nix.Filter.id, 'IdoNotExist'))); |
| 822 | + |
| 823 | + % test nix.Filter.accept_all |
| 824 | + filtered = f.blocks{1}.tags{1}.filter_features(nix.Filter.accept_all, ''); |
| 825 | + assert(size(filtered, 1) == 2); |
| 826 | + |
| 827 | + % test nix.Filter.id |
| 828 | + filtered = f.blocks{1}.tags{1}.filter_features(nix.Filter.id, filterID); |
| 829 | + assert(size(filtered, 1) == 1); |
| 830 | + assert(strcmp(filtered{1}.id, filterID)); |
| 831 | + |
| 832 | + % test nix.Filter.ids |
| 833 | + filtered = f.blocks{1}.tags{1}.filter_features(nix.Filter.ids, filterIDs); |
| 834 | + assert(size(filtered, 1) == 2); |
| 835 | + assert(strcmp(filtered{1}.id, filterIDs{1}) || strcmp(filtered{1}.id, filterIDs{2})); |
| 836 | + |
| 837 | + % test fail on nix.Filter.name |
| 838 | + err = 'unknown or unsupported filter'; |
| 839 | + try |
| 840 | + f.blocks{1}.tags{1}.filter_features(nix.Filter.name, 'someName'); |
| 841 | + catch ME |
| 842 | + assert(strcmp(ME.message, err)); |
| 843 | + end |
| 844 | + |
| 845 | + % test fail on nix.Filter.type |
| 846 | + err = 'unknown or unsupported filter'; |
| 847 | + try |
| 848 | + f.blocks{1}.tags{1}.filter_features(nix.Filter.type, 'someType'); |
| 849 | + catch ME |
| 850 | + assert(strcmp(ME.message, err)); |
| 851 | + end |
| 852 | + |
| 853 | + % test fail on nix.Filter.metadata |
| 854 | + err = 'unknown or unsupported filter'; |
| 855 | + try |
| 856 | + f.blocks{1}.tags{1}.filter_features(nix.Filter.metadata, 'someMetadata'); |
| 857 | + catch ME |
| 858 | + assert(strcmp(ME.message, err)); |
| 859 | + end |
| 860 | + |
| 861 | + % test fail on nix.Filter.source |
| 862 | + try |
| 863 | + f.blocks{1}.tags{1}.filter_features(nix.Filter.source, 'someSource'); |
| 864 | + catch ME |
| 865 | + assert(strcmp(ME.message, err)); |
| 866 | + end |
| 867 | +end |
0 commit comments