[NUI] Update webview TCs.
[platform/core/csapi/tizenfx.git] / test / Tizen.NUI.Tests / Tizen.NUI.Devel.Tests / testcase / internal / WebView / TSWebConsoleMessage.cs
1 using global::System;
2 using NUnit.Framework;
3 using NUnit.Framework.TUnit;
4 using Tizen.NUI.Components;
5 using Tizen.NUI.BaseComponents;
6 using System.Threading.Tasks;
7
8 namespace Tizen.NUI.Devel.Tests
9 {
10     using tlog = Tizen.Log;
11
12     [TestFixture]
13     [Description("internal/WebView/WebConsoleMessage")]
14     public class InternalWebConsoleMessageTest
15     {
16         private const string tag = "NUITEST";
17         private string urlForConsoleMessageTest = $"file://{Applications.Application.Current.DirectoryInfo.Resource}webview/console_info.html";
18         private BaseComponents.WebView webView = null;
19
20         [SetUp]
21         public void Init()
22         {
23             webView = new BaseComponents.WebView()
24             {
25                 Size = new Size(150, 100),
26             };
27             tlog.Info(tag, "Init() is called!");
28         }
29
30         [TearDown]
31         public void Destroy()
32         {
33             tlog.Info(tag, "Destroy() is being called!");
34             webView.Dispose();
35             tlog.Info(tag, "Destroy() is called!");
36         }
37
38         [Test]
39         [Category("P1")]
40         [Description("WebConsoleMessage constructor.")]
41         [Property("SPEC", "Tizen.NUI.WebConsoleMessage.WebConsoleMessage C")]
42         [Property("SPEC_URL", "-")]
43         [Property("CRITERIA", "CONSTR")]
44         [Property("COVPARAM", "")]
45         [Property("AUTHOR", "guowei.wang@samsung.com")]
46         public async Task WebConsoleMessageConstructor()
47         {
48             tlog.Debug(tag, $"WebConsoleMessageConstructor START");
49
50             TaskCompletionSource<bool> tcs = new TaskCompletionSource<bool>(false);
51             EventHandler<WebViewConsoleMessageReceivedEventArgs> onConsoleMessageReceive = (s, e) =>
52             {
53                 Assert.IsNotNull(e.ConsoleMessage, "null handle");
54                 Assert.IsInstanceOf<WebConsoleMessage>(e.ConsoleMessage, "Should return WebConsoleMessage instance.");
55                 tcs.TrySetResult(true);
56             };
57             webView.ConsoleMessageReceived += onConsoleMessageReceive;
58
59             webView.LoadUrl(urlForConsoleMessageTest);
60             var result = await tcs.Task;
61             Assert.IsTrue(result, "ConsoleMessageReceived event should be invoked");
62
63             // Make current thread (CPU) sleep...
64             await Task.Delay(1);
65
66             webView.ConsoleMessageReceived -= onConsoleMessageReceive;
67
68             tlog.Debug(tag, $"WebConsoleMessageConstructor END (OK)");
69         }
70
71         [Test]
72         [Category("P1")]
73         [Description("WebConsoleMessage Source.")]
74         [Property("SPEC", "Tizen.NUI.WebConsoleMessage.Source A")]
75         [Property("SPEC_URL", "-")]
76         [Property("CRITERIA", "PRO")]
77         [Property("COVPARAM", "")]
78         [Property("AUTHOR", "guowei.wang@samsung.com")]
79         public async Task WebConsoleMessageSource()
80         {
81             tlog.Debug(tag, $"WebConsoleMessageSource START");
82
83             TaskCompletionSource<bool> tcs = new TaskCompletionSource<bool>(false);
84             EventHandler<WebViewConsoleMessageReceivedEventArgs> onConsoleMessageReceive = (s, e) =>
85             {
86                 tlog.Info(tag, $"console message, Source: {e.ConsoleMessage.Source}");
87                 tlog.Info(tag, $"console message, Line: {e.ConsoleMessage.Line}");
88                 tlog.Info(tag, $"console message, Level: {e.ConsoleMessage.Level}");
89                 tlog.Info(tag, $"console message, Text: {e.ConsoleMessage.Text}");
90
91                 tcs.TrySetResult(true);
92             };
93             webView.ConsoleMessageReceived += onConsoleMessageReceive;
94
95             webView.LoadUrl(urlForConsoleMessageTest);
96             var result = await tcs.Task;
97             Assert.IsTrue(result, "ConsoleMessageReceived event should be invoked");
98
99             // Make current thread (CPU) sleep...
100             await Task.Delay(1);
101
102             webView.ConsoleMessageReceived -= onConsoleMessageReceive;
103
104             tlog.Debug(tag, $"WebConsoleMessageSource END (OK)");
105         }
106     }
107 }