OSDN Git Service

エラーログから艦隊名などの情報を削除する
[kancollesniffer/KancolleSniffer.git] / KancolleSniffer.Test / ErrorLogTest.cs
1 // Copyright (C) 2017 Kazuhiro Fujieda <fujieda@users.osdn.me>\r
2 //\r
3 // Licensed under the Apache License, Version 2.0 (the "License");\r
4 // you may not use this file except in compliance with the License.\r
5 // You may obtain a copy of the License at\r
6 //\r
7 //    http://www.apache.org/licenses/LICENSE-2.0\r
8 //\r
9 // Unless required by applicable law or agreed to in writing, software\r
10 // distributed under the License is distributed on an "AS IS" BASIS,\r
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
12 // See the License for the specific language governing permissions and\r
13 // limitations under the License.\r
14 \r
15 using ExpressionToCodeLib;\r
16 using Microsoft.VisualStudio.TestTools.UnitTesting;\r
17 \r
18 namespace KancolleSniffer.Test\r
19 {\r
20     [TestClass]\r
21     public class ErrorLogTest\r
22     {\r
23         [TestMethod]\r
24         public void RemoveTokenFromRequest()\r
25         {\r
26             var request =\r
27                 "api%5Fverno=1&api%5Ftoken=0123456abcdef&api%5Fport=0123456789";\r
28             var response = "";\r
29             ErrorLog.RemoveUnwantedInformation(ref request, ref response);\r
30             PAssert.That(() => request == "api%5Fverno=1&api%5Fport=0123456789", "トークンが中間");\r
31             var request2 = "api%5Fverno=1&api%5Ftoken=0123456abcdef";\r
32             ErrorLog.RemoveUnwantedInformation(ref request2, ref response);\r
33             PAssert.That(() => request2 == @"api%5Fverno=1", "トークンが末尾");\r
34             var request3 = "api%5Ftoken=0123456abcdef&api%5Fverno=1";\r
35             ErrorLog.RemoveUnwantedInformation(ref request3, ref response);\r
36             PAssert.That(() => request3 == @"api%5Fverno=1", "トークンが先頭");\r
37             var request4 = "api%5Ftoken=0123456abcdef";\r
38             ErrorLog.RemoveUnwantedInformation(ref request4, ref response);\r
39             PAssert.That(() => request4 == "", "トークン単独");\r
40             var request5 = "api%5Fbtime=83026279&api%5Ftoken=b936475084b75920aa646d2a609b23cf3838bbc1&api%5Fverno=1";\r
41             ErrorLog.RemoveUnwantedInformation(ref request5, ref response);\r
42             PAssert.That(() => request5 == "api%5Fverno=1", "戦闘APIの時刻印を削除");\r
43         }\r
44 \r
45         [TestMethod]\r
46         public void RemoveUnwantedInformationFromResponse()\r
47         {\r
48             var request = "";\r
49             var response1 = @"{""api_result"":1,""api_result_msg"":""成功"",""api_data"":" +\r
50                            @"{""api_basic"":{""api_member_id"":""123456""," +\r
51                            @"""api_nickname"":""ぱんなこった"",""api_nickname_id"":""12345678"",""api_active_flag"":1}}}";\r
52             ErrorLog.RemoveUnwantedInformation(ref request, ref response1);\r
53             PAssert.That(() => response1 ==\r
54                                @"{""api_result"":1,""api_result_msg"":""成功"",""api_data"":{""api_basic"":{""api_active_flag"":1}}}");\r
55             var response2 =\r
56                 @"{""api_deck_data"":[{""api_member_id"":123456,""api_id"":1,""api_name"":""第一艦隊"",""api_name_id"":""123456"",""api_mission"":[0,0,0,0],""api_flagship"":""0""}]}";\r
57             ErrorLog.RemoveUnwantedInformation(ref request, ref response2);\r
58             PAssert.That(() => response2 == @"{""api_deck_data"":[{""api_id"":1,""api_name"":"""",""api_mission"":[0,0,0,0],""api_flagship"":""0""}]}");\r
59         }\r
60     }\r
61 }