1 // Copyright (C) 2017 Kazuhiro Fujieda <fujieda@users.osdn.me>
\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
7 // http://www.apache.org/licenses/LICENSE-2.0
\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
16 using ExpressionToCodeLib;
\r
17 using KancolleSniffer.Notification;
\r
18 using Microsoft.VisualStudio.TestTools.UnitTesting;
\r
20 namespace KancolleSniffer.Test
\r
23 public class NotificationManagerTest
\r
25 private class TimeProvider
\r
27 private DateTime _now = new DateTime(2017, 11, 1);
\r
29 public DateTime GetNow()
\r
32 _now += TimeSpan.FromSeconds(1);
\r
37 private class Message
\r
39 public string Title { private get; set; }
\r
40 public string Body { private get; set; }
\r
41 public string Name { private get; set; }
\r
43 public bool Equals(Message other) =>
\r
44 other != null && Title == other.Title && Body == other.Body && Name == other.Name;
\r
46 public Message Repeat => new Message {Title = "[リピート] " + Title, Body = Body, Name = Name};
\r
47 public Message Cont => new Message {Title = "[継続] " + Title, Body = Body, Name = Name};
\r
54 public void SingleNotification()
\r
56 var time = new TimeProvider();
\r
57 Message result = null;
\r
59 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
60 manager.Enqueue("遠征終了", 1, "防空射撃演習");
\r
62 PAssert.That(() => new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"}.Equals(result));
\r
69 public void TwoNotificationAtSameTime()
\r
71 var time = new TimeProvider();
\r
72 Message result = null;
\r
74 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
75 manager.Enqueue("遠征終了", 1, "防空射撃演習");
\r
76 manager.Enqueue("疲労回復49", 1, "cond49");
\r
78 PAssert.That(() => new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"}.Equals(result));
\r
81 PAssert.That(() => result == null);
\r
83 PAssert.That(() => new Message {Title = "疲労が回復しました", Body = "第二艦隊", Name = "疲労回復"}.Equals(result));
\r
87 /// 一つ目の通知の一秒後に投入された通知は一秒ずらす
\r
90 public void TwoNotification1SecDelay()
\r
92 var time = new TimeProvider();
\r
93 Message result = null;
\r
95 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
96 manager.Enqueue("建造完了", 0, "");
\r
98 PAssert.That(() => new Message {Title = "建造が終わりました", Body = "第一ドック", Name = "建造完了"}.Equals(result));
\r
100 manager.Enqueue("建造完了", 1, "");
\r
102 PAssert.That(() => new Message {Title = "建造が終わりました", Body = "第二ドック", Name = "建造完了"}.Equals(result));
\r
109 public void SingleRepeatableNotification()
\r
111 var time = new TimeProvider();
\r
112 Message result = null;
\r
114 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
115 var expected = new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"};
\r
122 manager.Enqueue("遠征終了", 1, "防空射撃演習", 2);
\r
124 PAssert.That(() => expected.Equals(result));
\r
128 PAssert.That(() => expected.Repeat.Equals(result));
\r
132 PAssert.That(() => expected.Repeat.Equals(result));
\r
136 PAssert.That(() => result == null, elapsed.ToString());
\r
148 public void TwoRepeatableNotification()
\r
150 var time = new TimeProvider();
\r
151 Message result = null;
\r
153 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
154 var ensei = new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"};
\r
155 var hakuchi = new Message {Title = "泊地修理 第一艦隊", Body = "20分経過しました。", Name = "泊地修理20分経過"};
\r
162 manager.Enqueue("遠征終了", 1, "防空射撃演習", 10);
\r
164 PAssert.That(() => ensei.Equals(result));
\r
167 manager.Enqueue("泊地修理20分経過", 0, "", 5);
\r
169 PAssert.That(() => hakuchi.Equals(result));
\r
173 PAssert.That(() => hakuchi.Repeat.Equals(result), "泊地修理2回目");
\r
177 PAssert.That(() => ensei.Repeat.Equals(result), "遠征終了2回目");
\r
181 PAssert.That(() => result == null, elapsed.ToString());
\r
190 /// スケジュールがぶつかる二つの通知をリピートさせる
\r
193 public void TwoRepeatableNotification1SecDelay()
\r
195 var time = new TimeProvider();
\r
196 Message result = null;
\r
198 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
199 var ensei = new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"};
\r
200 var hakuchi = new Message {Title = "泊地修理 第一艦隊", Body = "20分経過しました。", Name = "泊地修理20分経過"};
\r
207 manager.Enqueue("遠征終了", 1, "防空射撃演習", 3);
\r
209 PAssert.That(() => ensei.Equals(result));
\r
212 manager.Enqueue("泊地修理20分経過", 0, "", 2);
\r
217 PAssert.That(() => hakuchi.Equals(result));
\r
221 PAssert.That(() => ensei.Repeat.Equals(result), "遠征終了2回目");
\r
225 PAssert.That(() => hakuchi.Repeat.Equals(result), "泊地修理2回目");
\r
229 PAssert.That(() => result == null, elapsed.ToString());
\r
241 public void RemoveRepeatableNotification()
\r
243 var time = new TimeProvider();
\r
244 Message result = null;
\r
246 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
247 var ensei = new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"};
\r
248 var nyukyo = new Message {Title = "入渠が終わりました", Body = "第一ドック 綾波改二", Name = "入渠終了"};
\r
255 manager.Enqueue("遠征終了", 1, "防空射撃演習", 10);
\r
257 PAssert.That(() => ensei.Equals(result));
\r
260 manager.Enqueue("入渠終了", 0, "綾波改二", 5);
\r
262 PAssert.That(() => nyukyo.Equals(result));
\r
265 manager.StopRepeat("入渠終了");
\r
270 PAssert.That(() => result == null, "入渠終了2回目はない");
\r
274 PAssert.That(() => ensei.Repeat.Equals(result), "遠征終了2回目");
\r
278 PAssert.That(() => result == null, elapsed.ToString());
\r
290 public void SuspendRepeat()
\r
292 var time = new TimeProvider();
\r
293 Message result = null;
\r
295 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
296 var expected = new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"};
\r
303 manager.Enqueue("遠征終了", 1, "防空射撃演習", 10);
\r
305 PAssert.That(() => expected.Equals(result));
\r
309 manager.SuspendRepeat();
\r
313 manager.ResumeRepeat();
\r
317 PAssert.That(() => expected.Repeat.Equals(result));
\r
321 PAssert.That(() => result == null, elapsed.ToString());
\r
330 /// リピートを例外付きで中断・再開する
\r
333 public void SuspendRepeatWithException()
\r
335 var time = new TimeProvider();
\r
336 Message result = null;
\r
338 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
339 var ensei = new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"};
\r
340 var taiha = new Message {Title = "大破した艦娘がいます", Body = "摩耶改二", Name = "大破警告"};
\r
347 manager.Enqueue("遠征終了", 1, "防空射撃演習", 10);
\r
349 PAssert.That(() => ensei.Equals(result));
\r
353 manager.SuspendRepeat("大破警告");
\r
356 manager.Enqueue("大破警告", "摩耶改二", 8);
\r
358 PAssert.That(() => taiha.Equals(result));
\r
362 PAssert.That(() => taiha.Repeat.Equals(result));
\r
366 manager.ResumeRepeat();
\r
370 PAssert.That(() => ensei.Repeat.Equals(result));
\r
374 PAssert.That(() => result == null, elapsed.ToString());
\r
383 /// リピート中の特定の通知を止める
\r
386 public void StopSpecificRepeatingNotification()
\r
388 var time = new TimeProvider();
\r
389 Message result = null;
\r
391 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
392 var expected1 = new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"};
\r
393 var expected2 = new Message {Title = "遠征が終わりました", Body = "第三艦隊 海上護衛任務", Name = "遠征終了"};
\r
400 manager.Enqueue("遠征終了", 1, "防空射撃演習", 10);
\r
402 PAssert.That(() => expected1.Equals(result));
\r
405 manager.Enqueue("遠征終了", 2, "海上護衛任務", 10);
\r
410 PAssert.That(() => expected2.Equals(result));
\r
414 manager.StopRepeat("遠征終了", 1);
\r
418 PAssert.That(() => expected2.Repeat.Equals(result));
\r
422 PAssert.That(() => result == null, elapsed.ToString());
\r
431 /// 継続中のリピートは艦隊やドックの番号だけ通知する
\r
434 public void ContinueRepeatWithoutSubject()
\r
436 var time = new TimeProvider();
\r
437 Message result = null;
\r
439 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
440 var expected1 = new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"};
\r
441 var expected2 = new Message {Title = "遠征が終わりました", Body = "第二艦隊 ", Name = "遠征終了"};
\r
448 manager.Enqueue("遠征終了", 1, "防空射撃演習", 10);
\r
450 PAssert.That(() => expected1.Equals(result));
\r
454 manager.StopRepeat("遠征終了", true);
\r
458 PAssert.That(() => expected2.Cont.Equals(result));
\r
462 manager.StopRepeat("遠征終了", 1);
\r
469 PAssert.That(() => result == null, elapsed.ToString());
\r
481 public void PreliminaryNotification()
\r
483 var time = new TimeProvider();
\r
484 Message result = null;
\r
486 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
487 var expected = new Message {Title = "[予告] 遠征が終わりました", Body = "第二艦隊 防空射撃演習", Name = "遠征終了"};
\r
488 manager.Enqueue("遠征終了", 1, "防空射撃演習", 0, true);
\r
490 PAssert.That(() => expected.Equals(result));
\r
494 /// 同時に通知されるタイトルが同じ通知をマージする
\r
497 public void MergeTwoNotificationsWithSameTitle()
\r
499 var time = new TimeProvider();
\r
500 Message result = null;
\r
502 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
503 manager.Enqueue("遠征終了", 1, "防空射撃演習", 10);
\r
504 manager.Enqueue("遠征終了", 2, "海上護衛任務", 10);
\r
507 new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習\r\n第三艦隊 海上護衛任務", Name = "遠征終了"}.Equals(result));
\r
511 /// マージされた二つの通知の一方を止める
\r
514 public void StopOneOfMergedNotifications()
\r
516 var time = new TimeProvider();
\r
517 Message result = null;
\r
519 new Scheduler((t, b, n) => { result = new Message {Title = t, Body = b, Name = n}; }, time.GetNow);
\r
520 var expected1 = new Message {Title = "遠征が終わりました", Body = "第二艦隊 防空射撃演習\r\n第三艦隊 海上護衛任務", Name = "遠征終了"};
\r
521 var expected2 = new Message {Title = "遠征が終わりました", Body = "第三艦隊 海上護衛任務", Name = "遠征終了"};
\r
528 manager.Enqueue("遠征終了", 1, "防空射撃演習", 10);
\r
529 manager.Enqueue("遠征終了", 2, "海上護衛任務", 10);
\r
531 PAssert.That(() => expected1.Equals(result));
\r
535 manager.StopRepeat("遠征終了", 1);
\r
539 PAssert.That(() => expected2.Repeat.Equals(result));
\r
543 PAssert.That(() => result == null, elapsed.ToString());
\r