高章伟
2022-02-24 2aa8da8af66aa8ae00f25831aed6bb0364176e7b
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
@isTest
public with sharing class NFM109RestTest {
    
    private static Id pricebookId = ControllerUtil.getStandardPricebook().Id;
    static Account createHospital( String hospitalName) {
        StaticParameter.EscapeNFM001AgencyContractTrigger = true;
        StaticParameter.EscapeNFM001Trigger = true;
        // 病院を作る
        Account hospital = new Account();
        hospital.recordtypeId = [Select Id FROM RecordType WHERE DeveloperName = 'HP'].id;
        hospital.Name = hospitalName;
        insert hospital;
        StaticParameter.EscapeAccountTrigger = true;
        return hospital;
    }
 
    static List<Account> selectStrategicDep( Account hospital) {
        // 戦略科室を得る
        List<Account> strategicDep = [SELECT ID, Name FROM Account WHERE parentId = :hospital.Id AND recordType.DeveloperName = 'Department_Class_GI'];
        return strategicDep;
    }
 
    static Account createDep( Account hospital, Account strategicDep) {
        // 診療科を作る
        Account dep = new Account();
        dep.recordtypeId = [Select Id FROM RecordType WHERE DeveloperName = 'Department_GI'].id;
        dep.Name = 'test dep';
        dep.ParentId = strategicDep.Id;
        dep.Department_Class__c = strategicDep.Id;
        dep.Hospital__c = hospital.Id;
        // dep.State_Text__c = '上海市';
        insert dep;
        return dep;
    }
 
    static Asset createAsset( Account hospital, Account strategicDep, Account dep) {
        // 製品を作る
        Product2 productA = new Product2( Name = 'テスト商品');
        insert productA;
 
        // 価格表エントリを作成する
        PricebookEntry entry = new PricebookEntry( Pricebook2Id = pricebookId, Product2Id = productA.Id);
        entry.UnitPrice = 0;
        entry.IsActive = true;
        entry.UseStandardPrice = false;
        entry.CurrencyIsoCode = 'CNY';
        entry.Product2Id = productA.Id;
        insert entry;
 
        // 納入機器を作成する
        Asset asset = new Asset();
        asset.Name = 'テスト機器';
        asset.AccountId = dep.Id;
        asset.Department_Class__c = strategicDep.Id;
        asset.Hospital__c = hospital.Id;
        asset.SerialNumber = 'testserial';
        asset.Quantity = 3;
        // asset.Extend_Gurantee_DateTo_Text__c =Date.today().addDays(30);
        // asset.IS_Extend_Gurantee_Txt__c =true;
        // asset.Order_No__c = 'BJ_2020';
 
        insert asset;
 
        return asset;
    }
 
 
    @IsTest
    static void myTest(){
        
        ControllerUtil.EscapeNFM001Trigger = true;
 
        //  病院、戦略科室、診療科の情報を作成します
        Account hospital = createHospital( 'test hospital');
        Account[] strategicDep = selectStrategicDep( hospital);
        Account dep = createDep( hospital, strategicDep[0]);
 
        // 納入機器を作る
        Asset asset = createAsset( hospital, strategicDep[0], dep);
 
        // 修理を作成する01
        Repair__c re = new Repair__c();
        re.SAPRepairNo__c = '000010168255';
        re.Account__c = dep.Id;
        re.Department_Class__c = strategicDep[0].Id;
        re.Hospital__c = hospital.Id;
        re.Delivered_Product__c = asset.Id;
        re.SERVICE_CONTRACT_JUDEGE_DAY__C = Date.today().addDays( -1000); // 维修合同判断日がサービス契約のだいぶ前
        re.Failure_Occurrence_Date__c  = Date.today();
        re.InspectionCategory_Zero__c = '0';
        re.IISE_Inspection_Branch_Zero__c = '1';
        insert re;
 
        PAE_DecisionRecord__c record = new PAE_DecisionRecord__c(
            PAE_DetermineResults__c = 'nonPAE',                    // PAE判定结果
            PAE_ConfirmationDate__c = Date.valueOf('2020-05-06'),  // OCSM QARA确认日
            PAE_Authenticator__c = '00510000005sEEM',              // OCSM QARA确认者
            PAE_reappear_confirm__c = '未确认'                       // 再现结果确认
        );
        record.PAE_Repair__c = re.Id;
        record.RecordTypeId = Schema.SObjectType.PAE_DecisionRecord__c.getRecordTypeInfosByDeveloperName().get('ASRCDecision').getRecordTypeId();
        insert record;
 
        PAE_DecisionRecordDetail__c detail1 = new PAE_DecisionRecordDetail__c(
            PAED_RCAC__c = 'Intake',                              // Intake/Final
            PAED_ManagementCode__c = 'test001',                     // Code
            PAED_Status__c = '有效',                                  // 状态
            PAED_ConfirmationDate__c = Date.valueOf('2020-05-06'),  // 确认日
            PAED_Affirmant__c = '00510000005sEEM',                  // 确认者
            PAE_DecisionRecordD__c = 'a3q1s0000008Sxg',             // PAE判定记录
            isInterfaceCreate__c = false,                           // 是否通过接口新建
            PAE_Judge__c = 'nonPAE',                                // PAE判定
            PAED_Reappear_Result__c = '不再現',                    // 再现結果
            InspectionCategory109__c = '0'
        );
        detail1.PAE_DecisionRecordD__c = record.Id;
        detail1.PAED_Repair__c = re.Id;
        insert detail1;
 
        // PAEDetail.PAE_Judge__c = intake.PaeFlag == 'true' ? 'PAE' : 'nonPAE'; 
        // PAEDetail.PAED_Reappear_Result__c = intake.NotReproduceFlag == 'true' ? '不再現' : '再現';
 
        PAE_DecisionRecordDetail__c detail2 = new PAE_DecisionRecordDetail__c(
            PAED_RCAC__c = 'Intake',                              // Intake/Final
            PAED_ManagementCode__c = 'GIA11',                     // Code
            PAED_Status__c = '有效',                                  // 状态
            PAED_ConfirmationDate__c = Date.valueOf('2020-05-06'),  // 确认日
            PAED_Affirmant__c = '00510000005sEEM',                  // 确认者
            PAE_DecisionRecordD__c = 'a3q1s0000008Sxg',             // PAE判定记录
            isInterfaceCreate__c = false,                           // 是否通过接口新建
            PAE_Judge__c = 'nonPAE',                                // PAE判定
            PAED_Reappear_Result__c = '不再現'                    // 再现結果
        );
        detail2.PAE_DecisionRecordD__c = record.Id;
        detail2.PAED_Repair__c = re.Id;
        insert detail2;
 
        PAE_DecisionRecord__c record2 = new PAE_DecisionRecord__c(
            PAE_DetermineResults__c = 'nonPAE',                    // PAE判定结果
            PAE_ConfirmationDate__c = Date.valueOf('2020-05-06'),  // OCSM QARA确认日
            PAE_Authenticator__c = '00510000005sEEM',              // OCSM QARA确认者
            PAE_reappear_confirm__c = '未确认'                       // 再现结果确认
        );
        record2.PAE_Repair__c = re.Id;
        record2.RecordTypeId = Schema.SObjectType.PAE_DecisionRecord__c.getRecordTypeInfosByDeveloperName().get('ASACDecision').getRecordTypeId();
        insert record2;
 
        List<PAE_DecisionRecord__c> PAEDecisionRecords = [select id,name from PAE_DecisionRecord__c where PAE_Repair__c = :re.Id];
        System.debug('PAEDecisionRecords.size()'+PAEDecisionRecords.size());
 
        Test.startTest();
 
        RestRequest req = new RestRequest();
        RestResponse res = new RestResponse();
 
        String JsonMsg = '{"InspectionRequest":{"InspectionResult":{"ThirdParty":"True",';
        JsonMsg += '"SAPRepairNotificationNo":"000010168255",';
        JsonMsg += '"Quotation":[{"RepairRank":"B","Parts":[{"Qty":"3","ItemCode":"GE782500","BomCode":"BM064248"}],';
        JsonMsg += '"CafeteriaFlag":"False","ActivityCode":["1002","3302"]}],';
        JsonMsg += '"ProductCode":"GIF-H190","Measure":{"CumulativeUses":"111","CumulativeTimes":"222"},';
        JsonMsg += '"IntakeInfo":[{"PaeFlag":"False","NotReproduceIntakeUniversalDesc":"投诉尚未确认","NotReproduceIntakeUniversal":"GIA11Z",';
        JsonMsg += '"NotReproduceFlag":"True","IntakeUniversalDesc":"无吸力","IntakeUniversal":"000"},';
        JsonMsg += '{"PaeFlag":"True","NotReproduceIntakeUniversalDesc":"","NotReproduceIntakeUniversal":"","NotReproduceFlag":"False",';
        JsonMsg += '"IntakeUniversalDesc":"No products in the RSA product list","IntakeUniversal":"GIA11"}],';
        JsonMsg += '"InspectionUserInEnglish":"Shuai Li","InspectionUser":"李帅","InspectionResultFlag":"False",';
        JsonMsg += '"InspectionDate":"20200716","InspectionComment":"0716_test Inspection","InspectionCategory":"0",';
        JsonMsg += '"InspectionBranchNo":"2","FailureCause":"0716_test failure comment",';
        JsonMsg += '"Failure":[{"Phenomenon":"5G","PaeFlag":"True","LocationGroupDesc":"插入部","LocationGroup":"7","LocationDesc":"C本体",';
        JsonMsg += '"Location":"A01","FinalUniversalDesc":"其他故障模式","FinalUniversal":"GIL1201Y","EtqPart":"","EtqCause":"-",';
        JsonMsg += '"EtqAsAnalyzed":"","Description":"A015GA6AA","Cause":"611"},{"Phenomenon":"4A","PaeFlag":"False",';
        JsonMsg += '"LocationGroupDesc":"内镜连接座部","LocationGroup":"1","LocationDesc":"本体","Location":"H01",';
        JsonMsg += '"FinalUniversalDesc":"外部金属部件的电气连接变弱-插入管和弯曲部分之间发生电气连续性错误(故障导致主体接地测试)",';
        JsonMsg += '"FinalUniversal":"GII2001A","EtqPart":"P0004","EtqCause":"C023","EtqAsAnalyzed":"AAEL0072","Description":"H014AB2AD",';
        JsonMsg += '"Cause":"980"}],"EtQManagementNo":"0716_test_etq","DomainCaption":"com.olympus.china","CafeteriaPlanFlag":"False"}}}';
        
        req.requestURI = 'services/apexrest/NFM109';
        req.httpMethod = 'POST';
        req.addHeader('content-type', 'application/json');
        req.requestBody = Blob.valueof(JsonMsg);
        RestContext.request = req;
        RestContext.response = res;
 
        NFM109Rest.execute();
 
        Test.stopTest();
        System.debug('response'+res.responseBody);
        re = [select id,name,SAP_Service_Repair_No__c,
                        IISE_Inspection_Branch_Zero__c,IISE_Inspection_Branch_Three__c,
                        IISE_confirmed_person__c,IISE_confirmed_person_en__c,
                        InspectionCategory_Zero__c,InspectionCategory_Three__c
                        from repair__c ];
 
        System.debug('re updated '+re);
        Map<Id,PAE_DecisionRecord__c> recordsMap = new Map<Id,PAE_DecisionRecord__c>([select id,name,PAE_reappear_confirm__c from PAE_DecisionRecord__c where PAE_Repair__c = :re.Id]);
        for (PAE_DecisionRecord__c ele : recordsMap.values()) {
            System.debug('record'+ele);
        }
 
        List<PAE_DecisionRecordDetail__c> details = [select id,PAED_ManagementCode__c,PAED_RCAC__c,PAED_Status__c,
                                                        PAE_Judge__c,PAE_DecisionRecordD__c,PAED_Repair__c,PAED_Repair__r.name,
                                                        LocationGroup__c,Location__c,Phenomenon__c,Description__c,Cause__c,EtqPart__c,
                                                        EtqAsAnalyzed__c,EtqCause__c,FinalUniversalDesc__c,PAED_Reappear_Result__c,InspectionCategory109__c 
                                                        from PAE_DecisionRecordDetail__c where PAE_DecisionRecordD__c in :recordsMap.keySet()];
        for (PAE_DecisionRecordDetail__c detail : details) {
            System.debug('detail'+detail);
        }
 
        List<BatchIF_Log__c> logs = [select id,name,type__c,ErrorLog__c,Last_Update_Date2__c from BatchIF_Log__c where type__c = 'NFM109'];
        System.debug('logs'+logs);
        
    }
 
}