scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2014 Google Inc. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license that can be |
| 5 | * found in the LICENSE file. |
| 6 | */ |
| 7 | |
| 8 | #include "DMJsonWriter.h" |
| 9 | |
halcanary | c79a391 | 2015-04-01 13:31:34 -0700 | [diff] [blame] | 10 | #include "ProcStats.h" |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 11 | #include "SkCommonFlags.h" |
Brian Osman | 57796b3 | 2019-01-25 18:02:59 +0000 | [diff] [blame] | 12 | #include "SkData.h" |
Brian Osman | fad5c77 | 2019-01-25 16:34:20 -0500 | [diff] [blame] | 13 | #include "SkJSON.h" |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 14 | #include "SkJSONWriter.h" |
mtklein | 1b24933 | 2015-07-07 12:21:21 -0700 | [diff] [blame] | 15 | #include "SkMutex.h" |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 16 | #include "SkOSFile.h" |
Ben Wagner | bf111d7 | 2016-11-07 18:05:29 -0500 | [diff] [blame] | 17 | #include "SkOSPath.h" |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 18 | #include "SkStream.h" |
Brian Osman | 57796b3 | 2019-01-25 18:02:59 +0000 | [diff] [blame] | 19 | #include "SkTArray.h" |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 20 | |
| 21 | namespace DM { |
| 22 | |
| 23 | SkTArray<JsonWriter::BitmapResult> gBitmapResults; |
reed | 086eea9 | 2016-05-04 17:12:46 -0700 | [diff] [blame] | 24 | SK_DECLARE_STATIC_MUTEX(gBitmapResultLock); |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 25 | |
| 26 | void JsonWriter::AddBitmapResult(const BitmapResult& result) { |
| 27 | SkAutoMutexAcquire lock(&gBitmapResultLock); |
| 28 | gBitmapResults.push_back(result); |
| 29 | } |
| 30 | |
scroggo | 0ee2627 | 2014-11-07 06:07:32 -0800 | [diff] [blame] | 31 | SkTArray<skiatest::Failure> gFailures; |
reed | 086eea9 | 2016-05-04 17:12:46 -0700 | [diff] [blame] | 32 | SK_DECLARE_STATIC_MUTEX(gFailureLock); |
scroggo | 0ee2627 | 2014-11-07 06:07:32 -0800 | [diff] [blame] | 33 | |
| 34 | void JsonWriter::AddTestFailure(const skiatest::Failure& failure) { |
| 35 | SkAutoMutexAcquire lock(gFailureLock); |
| 36 | gFailures.push_back(failure); |
| 37 | } |
| 38 | |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 39 | void JsonWriter::DumpJson() { |
| 40 | if (FLAGS_writePath.isEmpty()) { |
| 41 | return; |
| 42 | } |
| 43 | |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 44 | SkString path = SkOSPath::Join(FLAGS_writePath[0], "dm.json"); |
| 45 | sk_mkdir(FLAGS_writePath[0]); |
| 46 | SkFILEWStream stream(path.c_str()); |
| 47 | SkJSONWriter writer(&stream, SkJSONWriter::Mode::kPretty); |
| 48 | |
| 49 | writer.beginObject(); // root |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 50 | |
| 51 | for (int i = 1; i < FLAGS_properties.count(); i += 2) { |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 52 | writer.appendString(FLAGS_properties[i-1], FLAGS_properties[i]); |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 53 | } |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 54 | |
| 55 | writer.beginObject("key"); |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 56 | for (int i = 1; i < FLAGS_key.count(); i += 2) { |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 57 | writer.appendString(FLAGS_key[i-1], FLAGS_key[i]); |
| 58 | } |
| 59 | writer.endObject(); |
| 60 | |
| 61 | int maxResidentSetSizeMB = sk_tools::getMaxResidentSetSizeMB(); |
| 62 | if (maxResidentSetSizeMB != -1) { |
| 63 | writer.appendS32("max_rss_MB", maxResidentSetSizeMB); |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 64 | } |
| 65 | |
| 66 | { |
| 67 | SkAutoMutexAcquire lock(&gBitmapResultLock); |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 68 | writer.beginArray("results"); |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 69 | for (int i = 0; i < gBitmapResults.count(); i++) { |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 70 | writer.beginObject(); |
| 71 | |
| 72 | writer.beginObject("key"); |
| 73 | writer.appendString("name" , gBitmapResults[i].name.c_str()); |
| 74 | writer.appendString("config" , gBitmapResults[i].config.c_str()); |
| 75 | writer.appendString("source_type", gBitmapResults[i].sourceType.c_str()); |
mtklein | 20c1c04 | 2015-04-06 07:22:05 -0700 | [diff] [blame] | 76 | |
| 77 | // Source options only need to be part of the key if they exist. |
| 78 | // Source type by source type, we either always set options or never set options. |
| 79 | if (!gBitmapResults[i].sourceOptions.isEmpty()) { |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 80 | writer.appendString("source_options", gBitmapResults[i].sourceOptions.c_str()); |
mtklein | 20c1c04 | 2015-04-06 07:22:05 -0700 | [diff] [blame] | 81 | } |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 82 | writer.endObject(); // key |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 83 | |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 84 | writer.beginObject("options"); |
| 85 | writer.appendString("ext" , gBitmapResults[i].ext.c_str()); |
| 86 | writer.appendString("gamma_correct", gBitmapResults[i].gammaCorrect ? "yes" : "no"); |
| 87 | writer.endObject(); // options |
| 88 | |
| 89 | writer.appendString("md5", gBitmapResults[i].md5.c_str()); |
| 90 | |
| 91 | writer.endObject(); // 1 result |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 92 | } |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 93 | writer.endArray(); // results |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 94 | } |
| 95 | |
scroggo | 0ee2627 | 2014-11-07 06:07:32 -0800 | [diff] [blame] | 96 | { |
| 97 | SkAutoMutexAcquire lock(gFailureLock); |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 98 | if (gFailures.count() > 0) { |
| 99 | writer.beginObject("test_results"); |
| 100 | writer.beginArray("failures"); |
| 101 | for (int i = 0; i < gFailures.count(); i++) { |
| 102 | writer.beginObject(); |
| 103 | writer.appendString("file_name", gFailures[i].fileName); |
| 104 | writer.appendS32 ("line_no" , gFailures[i].lineNo); |
| 105 | writer.appendString("condition", gFailures[i].condition); |
| 106 | writer.appendString("message" , gFailures[i].message.c_str()); |
| 107 | writer.endObject(); // 1 failure |
| 108 | } |
| 109 | writer.endArray(); // failures |
| 110 | writer.endObject(); // test_results |
scroggo | 0ee2627 | 2014-11-07 06:07:32 -0800 | [diff] [blame] | 111 | } |
| 112 | } |
| 113 | |
Brian Osman | aae6388 | 2019-01-25 10:02:27 -0500 | [diff] [blame] | 114 | writer.endObject(); // root |
| 115 | writer.flush(); |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 116 | stream.flush(); |
| 117 | } |
| 118 | |
Brian Osman | fad5c77 | 2019-01-25 16:34:20 -0500 | [diff] [blame] | 119 | using namespace skjson; |
| 120 | |
Brian Osman | 57796b3 | 2019-01-25 18:02:59 +0000 | [diff] [blame] | 121 | bool JsonWriter::ReadJson(const char* path, void(*callback)(BitmapResult)) { |
| 122 | sk_sp<SkData> json(SkData::MakeFromFileName(path)); |
| 123 | if (!json) { |
| 124 | return false; |
| 125 | } |
| 126 | |
Brian Osman | fad5c77 | 2019-01-25 16:34:20 -0500 | [diff] [blame] | 127 | DOM dom((const char*)json->data(), json->size()); |
| 128 | const ObjectValue* root = dom.root(); |
| 129 | if (!root) { |
Brian Osman | 57796b3 | 2019-01-25 18:02:59 +0000 | [diff] [blame] | 130 | return false; |
| 131 | } |
| 132 | |
Brian Osman | fad5c77 | 2019-01-25 16:34:20 -0500 | [diff] [blame] | 133 | const ArrayValue* results = (*root)["results"]; |
| 134 | if (!results) { |
| 135 | return false; |
| 136 | } |
Brian Osman | 57796b3 | 2019-01-25 18:02:59 +0000 | [diff] [blame] | 137 | |
Brian Osman | fad5c77 | 2019-01-25 16:34:20 -0500 | [diff] [blame] | 138 | BitmapResult br; |
| 139 | for (const ObjectValue* r : *results) { |
| 140 | const ObjectValue& key = (*r)["key"].as<ObjectValue>(); |
| 141 | const ObjectValue& options = (*r)["options"].as<ObjectValue>(); |
| 142 | |
| 143 | br.name = key["name"].as<StringValue>().begin(); |
| 144 | br.config = key["config"].as<StringValue>().begin(); |
| 145 | br.sourceType = key["source_type"].as<StringValue>().begin(); |
| 146 | br.ext = options["ext"].as<StringValue>().begin(); |
| 147 | br.gammaCorrect = 0 == strcmp("yes", options["gamma_correct"].as<StringValue>().begin()); |
| 148 | br.md5 = (*r)["md5"].as<StringValue>().begin(); |
| 149 | |
| 150 | if (const StringValue* so = key["source_options"]) { |
| 151 | br.sourceOptions = so->begin(); |
Brian Osman | 57796b3 | 2019-01-25 18:02:59 +0000 | [diff] [blame] | 152 | } |
| 153 | callback(br); |
| 154 | } |
| 155 | return true; |
| 156 | } |
| 157 | |
scroggo | 7a10fb6 | 2014-11-04 07:21:10 -0800 | [diff] [blame] | 158 | } // namespace DM |