function res = test_fourValuedSignal_findIntervals
% test_fourValuedSignal_findIntervals - unit test function of findIntervals
%
% Syntax:
%    res = test_fourValuedSignal_findIntervals
%
% Inputs:
%    -
%
% Outputs:
%    res - true/false
%
% Other m-files required: none
% Subfunctions: none
% MAT-files required: none
%
% See also: none

% Authors:       Florian Lercher
% Written:       20-February-2024
% Last update:   ---
% Last revision: ---

% ------------------------------ BEGIN CODE -------------------------------

% signals
tt = true;
ff = false;
boolSig = pointSegmentSignal([0,1,2,2.5,3,4],[tt,tt,ff,tt,tt,ff,ff,tt,ff,ff,ff,tt]);
isUnknown = pointSegmentSignal.indicator(stlInterval(1.5,2.25,true,false),true,false);
isInconclusive = pointSegmentSignal.indicator(stlInterval(1.75,2.1,false,true),true,false);
sig = fourValuedSignal(kleeneSignal(boolSig,isUnknown),isInconclusive);

% test case definition
test_cases = {
    % {sig, match, expected}
    {sig, fourValued.True, [stlInterval(0,1,true,false),stlInterval(1,1.5,false,false),stlInterval(2.5,3,false),stlInterval(4,inf,false)]};
    {sig, fourValued.Unknown, [stlInterval(1.5,1.75,true,true),stlInterval(2.1,2.25,false,false)]};
    {sig, fourValued.False, [stlInterval(1),stlInterval(2.25,2.5,true,true),stlInterval(3,4,true)]};
    {sig, fourValued.Inconclusive, [stlInterval(1.75,2.1,false,true)]};
};

% run tests
for i = 1:length(test_cases)
    sig = test_cases{i}{1};
    match = test_cases{i}{2};
    expected = test_cases{i}{3};
    actual = sig.findIntervals(match);
    if ~compareIntervals(actual,expected)
        res = false;
        return;
    end
end

res = true;

% ------------------------------ END OF CODE ------------------------------
