00001 #ifndef FULLBYPASSBARRELTEST_H
00002 #define FULLBYPASSBARRELTEST_H
00003
00004 #include "../ipc/TestRequest.h"
00005 #include "../ipc/CalibrationController.h"
00006 #include "../ipc/ScanLibrary.h"
00007 #include "../ipc/CalibrationController.hh"
00008 #include "../CalibrationControllerImpl.h"
00009
00010 #include "../SctApiAccessException.h"
00011 #include "../SctApiCall.h"
00012 #include "Sct/LogicErrors.h"
00013
00014 #include <Sct/AbcdScans.h>
00015 #include <iostream>
00016 #include <vector>
00017
00018 using namespace Sct;
00019 using namespace SctCalibrationController::Ipc;
00020 using namespace SctCalibrationController;
00021
00022 namespace SctCalibrationController {
00023 namespace Scripts {
00024
00027 class FullBypassBarrelTest : public TestRequestImpl {
00028 private:
00029 static const bool registeredInTestLibrary;
00030
00031 public:
00032 static Sct_CalibrationController::TestRequest_ptr instance() {
00033 static FullBypassBarrelTest fb;
00034 fb.setFitAlgorithm("NONE");
00035 fb.setAnalysisAlgorithm("FullBypassTest");
00036 return fb._this();
00037 }
00038
00039 virtual void startTestRealImpl(Sct_SctApi::SctApiIPC_ptr api, string& name, unsigned short& testVariable, unsigned long& nScans, vector<double>& testPoints) {
00040 this->api = Sct_SctApi::SctApiIPC::_duplicate(api);
00041
00042
00043 APICALL(api, modifyABCDVar(ST_COMPRESSION, 1), "FullBypassBarrelTest::startTest")
00044
00045
00046 APICALL(api, modifyABCDVar(ST_EDGE_DETECT, 0), "FullBypassBarrelTest::startTest")
00047
00048
00049 APICALL(api, modifyABCDVar(ST_MASK, 3), "FullBypassBarrelTest::startTest")
00050
00051
00052 APICALL(api, modifyABCDVar(ST_SEND_MASK, 1), "FullBypassBarrelTest::startTest")
00053
00054 name = "FullBypassTest";
00055 testVariable = ST_ELAPSED;
00056
00057
00058
00059
00060
00061 vdd.clear();
00062 vdd.push_back(4.0);
00063
00064 testPoints = vdd;
00065 nScans = testPoints.size();
00066 }
00067
00071 virtual Sct_CalibrationController::ScanRequest_ptr getNextScanRealImpl(unsigned long index) {
00072 if (CORBA::is_nil(api))
00073 throw InvariantViolatedError("Api pointer is 0 in getNextScan!", __FILE__, __LINE__);
00074
00075
00076
00077
00078
00079
00080 Sct_CalibrationController::ScanLibrary_var sl = CalibrationControllerImpl::instance()->getScanLibrary();
00081 return sl->tokenScan();
00082 }
00083
00084 virtual bool canFeedbackRealImpl() {
00085 return false;
00086 }
00087
00088 virtual void endTestRealImpl() {
00089 if (CORBA::is_nil(api))
00090 throw InvariantViolatedError("Api pointer is 0 in endTest!", __FILE__, __LINE__);
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101 api = Sct_SctApi::SctApiIPC::_nil();
00102 }
00103
00104 private:
00105 FullBypassBarrelTest() {}
00106 Sct_SctApi::SctApiIPC_var api;
00107 std::vector<double> vdd;
00108 };
00109 }
00110 }
00111 #endif //FULLBYPASSBARRELTEST_H