88b524ebb1e04cfe2444fefe16ff87cd83770a6e
[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             webView.ConsoleMessageReceived -= onConsoleMessageReceive;
64
65             tlog.Debug(tag, $"WebConsoleMessageConstructor END (OK)");
66         }
67
68         [Test]
69         [Category("P1")]
70         [Description("WebConsoleMessage Source.")]
71         [Property("SPEC", "Tizen.NUI.WebConsoleMessage.Source A")]
72         [Property("SPEC_URL", "-")]
73         [Property("CRITERIA", "PRO")]
74         [Property("COVPARAM", "")]
75         [Property("AUTHOR", "guowei.wang@samsung.com")]
76         public async Task WebConsoleMessageSource()
77         {
78             tlog.Debug(tag, $"WebConsoleMessageSource START");
79
80             TaskCompletionSource<bool> tcs = new TaskCompletionSource<bool>(false);
81             EventHandler<WebViewConsoleMessageReceivedEventArgs> onConsoleMessageReceive = (s, e) =>
82             {
83                 tlog.Info(tag, $"console message, Source: {e.ConsoleMessage.Source}");
84                 tlog.Info(tag, $"console message, Line: {e.ConsoleMessage.Line}");
85                 tlog.Info(tag, $"console message, Level: {e.ConsoleMessage.Level}");
86                 tlog.Info(tag, $"console message, Text: {e.ConsoleMessage.Text}");
87
88                 tcs.TrySetResult(true);
89             };
90             webView.ConsoleMessageReceived += onConsoleMessageReceive;
91
92             webView.LoadUrl(urlForConsoleMessageTest);
93             var result = await tcs.Task;
94
95             webView.ConsoleMessageReceived -= onConsoleMessageReceive;
96
97             tlog.Debug(tag, $"WebConsoleMessageSource END (OK)");
98         }
99     }
100 }