File: BenchmarkResultsTests.swift

package info (click to toggle)
swiftlang 6.0.3-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,519,992 kB
  • sloc: cpp: 9,107,863; ansic: 2,040,022; asm: 1,135,751; python: 296,500; objc: 82,456; f90: 60,502; lisp: 34,951; pascal: 19,946; sh: 18,133; perl: 7,482; ml: 4,937; javascript: 4,117; makefile: 3,840; awk: 3,535; xml: 914; fortran: 619; cs: 573; ruby: 573
file content (128 lines) | stat: -rw-r--r-- 5,075 bytes parent folder | download
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
/*
 This source file is part of the Swift.org open source project

 Copyright (c) 2022 Apple Inc. and the Swift project authors
 Licensed under Apache License v2.0 with Runtime Library Exception

 See https://swift.org/LICENSE.txt for license information
 See https://swift.org/CONTRIBUTORS.txt for Swift project authors
*/

import XCTest
@testable import SwiftDocC

class BenchmarkResultsTests: XCTestCase {
    func testDecodingLegacyFormat() throws {
        let data = try XCTUnwrap(legacyBenchmark.data(using: .utf8))
        let results = try JSONDecoder().decode(BenchmarkResults.self, from: data)
        
        XCTAssertEqual(results.platformName, "macOS")
        XCTAssertEqual(results.doccArguments, ["convert", "TestBundle.docc"])
        XCTAssertEqual(results.timestamp.timeIntervalSince1970, testDate.timeIntervalSince1970, accuracy: 1.0) // The encoded format doesn't include sub-second information.
        
        // Unordered metrics should be ordered by kind (in the order duration, bytesInMemory, bytesOnDisk, checksum), and then by name.
        XCTAssertEqual(results.metrics, [
            .init(id: "duration-bundle-registration", displayName: "Duration for \'bundle-registration\'", value: .duration(0.108)),
            .init(id: "duration-convert-action", displayName: "Duration for \'convert-action\'", value: .duration(0.139)),
            .init(id: "duration-navigation-index", displayName: "Duration for \'navigation-index\'", value: .duration(0.0)),
            .init(id: "test-extra-duration", displayName: "Duration for \'test-extra\'", value: .duration(1.234)),
            .init(id: "peak-memory", displayName: "Peak memory footprint", value: .bytesInMemory(8273920)),
            .init(id: "test-extra-memory", displayName: "Test extra memory footprint", value: .bytesInMemory(1234567)),
            .init(id: "data-subdirectory-output-size", displayName: "Data subdirectory size", value: .bytesOnDisk(181337)),
            .init(id: "index-subdirectory-output-size", displayName: "Index subdirectory size", value: .bytesOnDisk(13768)),
            .init(id: "test-extra-output-size", displayName: "Test extra output size", value: .bytesOnDisk(12345678)),
            .init(id: "total-archive-output-size", displayName: "Total DocC archive size", value: .bytesOnDisk(1231030)),
            .init(id: "topic-anchor-hash", displayName: "Topic Anchor Checksum", value: .checksum("5afbde3ec6d3ee7b84e8aa1342f6839a")),
            .init(id: "topic-graph-hash", displayName: "Topic Graph Checksum", value: .checksum("9dd02a80ae466010c8925aebe9a1ca02"))
        ])
    }
}


// The legacy format encoded the date using the current locale.
//
// The expectation is that benchmark files are not compared across machines.
//
// Instead of using a hardcoded date string in a specific locale, this test encodes a new value using the current locale
// behaves the same as the real use case, regardless of the current locale.

private let testDate = Date()
private let legacyEncodedDate: String = {
    let dateFormatter = DateFormatter()
    dateFormatter.dateStyle = .medium
    dateFormatter.timeStyle = .medium
    return dateFormatter.string(from: testDate)
}()

private let legacyBenchmark = """
{
  "arguments": [
    "convert",
    "TestBundle.docc"
  ],
  "platform": "macOS",
  "metrics": [
    {
      "displayName": "Duration for 'bundle-registration' (msec)",
      "result": 108,
      "identifier": "duration-bundle-registration"
    },
    {
      "displayName": "Duration for 'convert-action' (msec)",
      "result": 139,
      "identifier": "duration-convert-action"
    },
    {
      "displayName": "Test extra memory footprint (bytes)",
      "result": 1234567,
      "identifier": "test-extra-memory"
    },
    {
      "displayName": "Topic Graph Checksum",
      "result": "9dd02a80ae466010c8925aebe9a1ca02",
      "identifier": "topic-graph-hash"
    },
    {
      "displayName": "Topic Anchor Checksum",
      "result": "5afbde3ec6d3ee7b84e8aa1342f6839a",
      "identifier": "topic-anchor-hash"
    },
    {
      "displayName": "Peak memory footprint (bytes)",
      "result": 8273920,
      "identifier": "peak-memory"
    },
    {
      "displayName": "Duration for 'navigation-index' (msec)",
      "result": 0,
      "identifier": "duration-navigation-index"
    },
    {
      "displayName": "Duration for 'test-extra' (msec)",
      "result": 1234,
      "identifier": "test-extra-duration"
    },
    {
      "displayName": "Total DocC archive size (bytes)",
      "result": 1231030,
      "identifier": "total-archive-output-size"
    },
    {
      "displayName": "Data subdirectory size (bytes)",
      "result": 181337,
      "identifier": "data-subdirectory-output-size"
    },
    {
      "displayName": "Test extra output size (bytes)",
      "result": 12345678,
      "identifier": "test-extra-output-size"
    },
    {
      "displayName": "Index subdirectory size (bytes)",
      "result": 13768,
      "identifier": "index-subdirectory-output-size"
    }
  ],
  "date": "\(legacyEncodedDate)"
}
"""