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
|
/* -*- 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", () => {
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 loop = new MainLoop (null);
try {
var sr = new GXml.StreamReader (f.read ());
Test.timer_start ();
var d = sr.read ();
message ("Initial Parse: %g sec for %d nodes", Test.timer_elapsed (), d.document_element.child_nodes.length);
Test.timer_start ();
Idle.add (()=>{
((GXml.Element) d.document_element).parse_buffer_async.begin ((obj, res)=>{
try {
((GXml.Element) d.document_element).parse_buffer_async.end (res);
} catch (GLib.Error e) {
warning ("Error: %s", e.message);
}
});
if (d.document_element.child_nodes.item (10079).child_nodes.length == 0) {
return Source.CONTINUE;
}
if (((GXml.Element) d.document_element).parse_pending () != 0) {
return Source.CONTINUE;
}
message ("Pending to parse: %u", ((GXml.Element) d.document_element).parse_pending ());
message ("Parsed buffers: %g sec", Test.timer_elapsed ());
assert (d.document_element.child_nodes.item (10079) is GXml.Element);
assert (d.document_element.child_nodes.item (10079).child_nodes.length != 0);
loop.quit ();
return Source.REMOVE;
});
} catch (GLib.Error e) {
warning ("Error: %s", e.message);
}
loop.run ();
});
return Test.run ();
}
}
|