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
|
/* -*- Mode: vala; indent-tabs-mode: nil; c-basic-offset: 2; tab-width: 2 -*- */
/* StreamReaderPerformanceAsyncReadUnparsedTest.vala
*
* Copyright (C) 2019 Daniel Espinosa <esodan@gmail.com>
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, see <http://www.gnu.org/licenses/>.
*
* Authors:
* Daniel Espinosa <esodan@gmail.com>
*/
using GXml;
class GXmlTest.Suite : GLib.Object
{
static int main (string[] args)
{
GLib.Intl.setlocale (GLib.LocaleCategory.ALL, "");
Test.init (ref args);
Test.add_func ("/gxml/stream-reader/performance", () => {
var loop = new MainLoop (null);
var timer = new Timer ();
ulong time = 0;
try {
File dir = File.new_for_path (GXmlTestConfig.TEST_DIR);
assert (dir.query_exists ());
File f = File.new_for_uri (dir.get_uri ()+"/test-large.xml");
assert (f.query_exists ());
var sr = new GXml.StreamReader (f.read ());
var d = sr.read ();
timer.elapsed (out time);
message ("Initial Parse: %lu ms for %d nodes", time / 1000, d.document_element.child_nodes.length);
Idle.add (()=>{
try {
((GXml.Element) d.document_element).parse_buffer ();
timer.elapsed (out time);
message ("Parse root: %lu ms", time / 1000);
loop.quit ();
} catch (GLib.Error e) {
warning ("Error: %s", e.message);
assert_not_reached ();
}
return Source.REMOVE;
});
} catch (GLib.Error e) {
warning ("Error: %s", e.message);
}
loop.run ();
});
return Test.run ();
}
}
|