aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/Utilities/Tango.UITests/MainWindow.xaml.cs
blob: 2fad8b46b7dc5f54cdc61613c7f8bc34bbb33b0a (plain)
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
using EFCache;
using Microsoft.Win32;
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.Windows.Threading;
using Tango.BL;
using Tango.BL.Builders;
using Tango.BL.Catalogs;
using Tango.BL.Entities;
using Tango.Core;
using Tango.Core.Commands;
using Tango.DragAndDrop;
using Tango.FirmwareUpdateLib;
using Tango.FirmwareUpdateLib.WPF;
using Tango.Logging;
using Tango.SharedUI;
using Tango.Web;
using System.Data;
using System.Data.SqlClient;
using System.Security.Permissions;
using TableDependency.SqlClient.Base;
using TableDependency.SqlClient;
using TableDependency.SqlClient.Base.EventArgs;
using TableDependency.SqlClient.Base.Abstracts;
using Tango.Core.Components;
using System.Text.RegularExpressions;

namespace Tango.UITests
{
    /// <summary>
    /// Interaction logic for MainWindow.xaml
    /// </summary>
    public partial class MainWindow : Window
    {
        private ITableDependency _dep;

        private DataSource _dataSource;

        public MainWindow()
        {
            //_dataSource = new DataSource()
            //{
            //    Address = "twine.database.windows.net",
            //    Catalog = "Tango_DEV",
            //    Type = DataSourceType.SQLServer,
            //    UserName = "Roy",
            //    Password = "Aa123456",
            //    IntegratedSecurity = false,
            //};

            //InitializeComponent();
            //EntityFrameworkCache.Initialize(new MyMemoryCache() { Expiration = TimeSpan.FromMinutes(1) });


            //this.Closing += MainWindow_Closing;

            CmdCommand command = new CmdCommand("wmic", "pagefile list /format:list");
            var result = command.Run().Result;

            Regex regEx = new Regex("Name=(.+)");
            var pageFiles = regEx.Matches(result.StandardOutput).OfType<Match>().Select(x => x.Groups.OfType<Group>().LastOrDefault()).ToList().Select(x => x.Value.Replace("\n", "").Replace("\r", "")).ToList();

            

            //var matches = matches.OfType<Match>().Select(x => x.Groups.OfType<Group>().Last().Value.Replace("\n","").Replace("\r","")).ToList();


        }

        private void MainWindow_Closing(object sender, System.ComponentModel.CancelEventArgs e)
        {
            if (_dep != null)
            {
                _dep.Stop();
                _dep.Dispose();
            }
        }


        private void btnStart_Click(object sender, RoutedEventArgs e)
        {
            Stopwatch watch = Stopwatch.StartNew();

            using (ObservablesContext db = ObservablesContext.CreateDefault(_dataSource))
            {
                var users = db.Users.ToList();
                var jobs = new JobsCollectionBuilder(db).SetAll().WithSegments().WithBrushStops().Build();
                var first_job = jobs.First();

                if (first_job.Name == "Changed Name 2")
                {
                    Debug.WriteLine("Changed and cached !!!");
                }
                else
                {
                    Debug.WriteLine("Not working.");
                }
            }

            Debug.WriteLine($"Time to complete: {watch.Elapsed.TotalSeconds} seconds");
        }

        private void btnChange_Click(object sender, RoutedEventArgs e)
        {
            using (ObservablesContext db = ObservablesContext.CreateDefault(_dataSource))
            {
                var jobs = new JobsCollectionBuilder(db).SetAll().WithSegments().WithBrushStops().Build();
                var first_job = jobs.First();
                first_job.Name = "Changed Name 2";
                db.SaveChanges();
            }
        }

        private void btnListen_Click(object sender, RoutedEventArgs e)
        {
            String str = _dataSource.ToConnection().ConnectionString;

            var dep = new SqlTableDependency<DAL.Remote.DB.USER>(str, "USERS", "dbo");
            dep.TraceLevel = TraceLevel.Verbose;
            dep.TraceListener = new TextWriterTraceListener(Console.Out);

            dep.OnChanged += Changed;
            dep.Start();

            _dep = dep;
        }

        private void Changed(object sender, RecordChangedEventArgs<DAL.Remote.DB.USER> e)
        {
            var changedEntity = e.Entity;

            Console.WriteLine("DML operation: " + e.ChangeType);

            Console.WriteLine(changedEntity.ToJsonString());
        }
    }
}