From d64ff56608283eef9677f1f36bc2afcdc96fccc2 Mon Sep 17 00:00:00 2001 From: Julia Pineda Date: Mon, 9 Oct 2023 13:07:54 +0800 Subject: [PATCH] Add attr tests Signed-off-by: Julia Pineda --- test/AD4630_24Tests.m | 54 +++++++++++++++++++++++++++++++++++++--- test/AD7768_1Tests.m | 58 +++++++++++++++++++++++++++++++++++++++---- 2 files changed, 103 insertions(+), 9 deletions(-) diff --git a/test/AD4630_24Tests.m b/test/AD4630_24Tests.m index b06a676..e83898a 100644 --- a/test/AD4630_24Tests.m +++ b/test/AD4630_24Tests.m @@ -1,12 +1,18 @@ classdef AD4630_24Tests < HardwareTests - properties(TestParameter) - end properties uri = 'ip:analog-2.local'; author = 'ADI'; end - + + properties(TestParameter) + sample_rate = {{1000,2000000,30000,0.0015,10}}; + sample_averaging_length = { ... + '2', '4', '8', '16', '32', '64', '128', '256', ... + '512', '1024', '2048', '4096', '8192', '16384', ... + '32768', '65536'}; + end + methods(TestClassSetup) % Check hardware connected function CheckForHardware(testCase) @@ -19,9 +25,49 @@ function CheckForHardware(testCase) function testAD4630_24Smoke(testCase) adc = adi.AD4630_24.Rx('uri',testCase.uri); - data = adc(); + [data,valid] = adc(); + adc.release(); + testCase.assertTrue(valid); + testCase.assertTrue(sum(abs(double(data)))>0); + end + + function testAD7768_1AttrSamplesPerFrame(testCase,sample_rate) + % TODO: Test this test + adc = adi.AD7768_1.Rx; + adc.uri = testCase.uri; + + start = sample_rate{1}; + stop = sample_rate{2}; + step = sample_rate{3}; + tol = sample_rate{4}; + repeats = sample_rate{5}; + numints = round((stop-start)/step); + for ii = 1:repeats + ind = randi([0, numints]); + val = start+(step*ind); + adc.SampleRate = num2str(val); + [data, valid] = adc(); + ret_val = adc.getDeviceAttributeRAW('sample_rate',8); + adc.release(); + testCase.assertTrue(valid); + testCase.assertTrue(sum(abs(double(data)))>0); + testCase.verifyEqual(str2double(ret_val),val,'RelTol',tol,... + 'Sample rate unexpected') + end + end + + function testAD4630_24AttrSampleAveragingLength(testCase,sample_averaging_length) + % TODO: Test this test + adc = adi.AD4630_24.Rx; + adc.uri = testCase.uri; + val = sample_averaging_length; + adc.SampleAveragingLength = val; + [data,valid] = adc(); + ret_val = adc.getDeviceAttributeRAW('sample_averaging',8); adc.release(); + testCase.assertTrue(valid); testCase.assertTrue(sum(abs(double(data)))>0); + testCase.assertTrue(strcmp(val,string(ret_val))); end end diff --git a/test/AD7768_1Tests.m b/test/AD7768_1Tests.m index ed62dac..79bbbe2 100644 --- a/test/AD7768_1Tests.m +++ b/test/AD7768_1Tests.m @@ -8,9 +8,14 @@ properties(TestParameter) % start frequency. stop frequency, step, tolerance, repeats signal_test = {{1000,125000,2500,0.015,10}}; + samples_per_frame = {{2^1,2^24,2^8,0.0,10}}; + common_mode_volts sample_rate = {'256000', '128000', '64000', ... '32000', '16000', '8000', '4000', ... '2000', '1000'}; + common_mode_voltage = { '(AVDD1-AVSS)/2','2V5', ... + '2V05','1V9','1V65','1V1','0V9', ... + 'OFF'}; end methods(TestClassSetup) @@ -37,8 +42,9 @@ function CheckForHardware(testCase) function testAD7768_1Smoke(testCase) adc = adi.AD7768_1.Rx; adc.uri = testCase.uri; - data = adc(); + [data,valid] = adc(); adc.release(); + testCase.assertTrue(valid); testCase.assertTrue(sum(abs(double(data)))>0); end @@ -62,9 +68,10 @@ function testAD7768_1Signal(testCase,signal_test) frequency = start+(step*ind); m2k_class.control(siggen, 0, [frequency, 0.5, 0, 0]); for k = 1:5 - data = adc(); + [data,valid] = adc(); end freqEst = testCase.estFrequencyMax(data,str2double(adc.SampleRate)); + testCase.assertTrue(valid); testCase.assertTrue(sum(abs(double(data)))>0); testCase.verifyEqual(freqEst,frequency,'RelTol',tol,... 'Frequency of signal unexpected') @@ -73,17 +80,58 @@ function testAD7768_1Signal(testCase,signal_test) m2k_class.contextClose(); end - function testAD7768_1Attr(testCase,sample_rate) - % FIXME: Hangs unless board is rebooted + function testAD7768_1AttrSampleRate(testCase,sample_rate) + % FIXME: Hangs unless board is rebooted adc = adi.AD7768_1.Rx; adc.uri = testCase.uri; val = sample_rate; adc.SampleRate = val; - adc(); + [data,valid] = adc(); ret_val = adc.getDeviceAttributeRAW('sampling_frequency',8); adc.release(); + testCase.assertTrue(valid); + testCase.assertTrue(sum(abs(double(data)))>0); + testCase.assertTrue(strcmp(val,string(ret_val))); + end + + function testAD7768_1AttrCommonModeVolage(testCase,common_mode_voltage) + % FIXME: Hangs unless board is rebooted + adc = adi.AD7768_1.Rx; + adc.uri = testCase.uri; + val = common_mode_voltage; + adc.CommonModeVolts = val; + [data,valid] = adc(); + ret_val = adc.getDeviceAttributeRAW('common_mode_voltage',8); + adc.release(); + testCase.assertTrue(valid); + testCase.assertTrue(sum(abs(double(data)))>0); testCase.assertTrue(strcmp(val,string(ret_val))); end + + function testAD7768_1AttrSamplesPerFrame(testCase,samples_per_frame) + % This is not written to the device. Should this even be tested? + adc = adi.AD7768_1.Rx; + adc.uri = testCase.uri; + + start = samples_per_frame{1}; + stop = samples_per_frame{2}; + step = samples_per_frame{3}; + tol = samples_per_frame{4}; + repeats = samples_per_frame{5}; + numints = round((stop-start)/step); + for ii = 1:repeats + ind = randi([0, numints]); + val = start+(step*ind); + adc.SamplesPerFrame = val; + [data, valid] = adc(); + [ret_val,~] = size(data); + adc.release(); + testCase.assertTrue(valid); + testCase.assertTrue(sum(abs(double(data)))>0); + testCase.verifyEqual(ret_val,val,'RelTol',tol,... + 'Frequency of signal unexpected') + end + end end end