Skip to content

Commit

Permalink
PoC for TDS Perf Tests
Browse files Browse the repository at this point in the history
  • Loading branch information
bwaresiak committed Nov 7, 2024
1 parent 5de0a61 commit 0d6346a
Show file tree
Hide file tree
Showing 3 changed files with 94 additions and 1 deletion.
10 changes: 10 additions & 0 deletions .swiftpm/xcode/xcshareddata/xcschemes/TrackerRadarKit.xcscheme
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,16 @@
ReferencedContainer = "container:">
</BuildableReference>
</TestableReference>
<TestableReference
skipped = "NO">
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "TrackerRadarKitPerformanceTests"
BuildableName = "TrackerRadarKitPerformanceTests"
BlueprintName = "TrackerRadarKitPerformanceTests"
ReferencedContainer = "container:">
</BuildableReference>
</TestableReference>
</Testables>
</TestAction>
<LaunchAction
Expand Down
5 changes: 4 additions & 1 deletion Package.swift
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,9 @@ let package = Package(
resources: [
.process("Resources/trackerData.json"),
.process("Resources/mockTrackerData.json")
])
]),
.testTarget(
name: "TrackerRadarKitPerformanceTests",
dependencies: ["TrackerRadarKit"])
]
)
Original file line number Diff line number Diff line change
@@ -0,0 +1,80 @@
//
// NextTrackerDataSetPerformanceTests.swift
//
// Copyright © 2021 DuckDuckGo. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//


Check failure on line 19 in Tests/TrackerRadarKitPerformanceTests/NextTrackerDataSetPerformanceTests.swift

View workflow job for this annotation

GitHub Actions / Run SwiftLint

Vertical Whitespace Violation: Limit vertical whitespace to a single empty line; currently 2 (vertical_whitespace)
import Foundation
import XCTest
import TrackerRadarKit
import WebKit

class NextTrackerDataSetPerformanceTests: XCTestCase {

static func nextURL(filename: String) -> URL {
return URL(string: "https://staticcdn.duckduckgo.com/trackerblocking/v5/next/\(filename)")!
}

var nextiOSTDS: TrackerData!


Check failure on line 33 in Tests/TrackerRadarKitPerformanceTests/NextTrackerDataSetPerformanceTests.swift

View workflow job for this annotation

GitHub Actions / Run SwiftLint

Vertical Whitespace Violation: Limit vertical whitespace to a single empty line; currently 2 (vertical_whitespace)
override func setUp() async throws {
try await super.setUp()

let (data, _) = try await URLSession.shared.data(from: Self.nextURL(filename: "ios-tds.json"))

nextiOSTDS = try JSONDecoder().decode(TrackerData.self, from: data)

print("Next TDS prepared")
}

func testPerformanceOfNext_iOSTDS() throws {

let rules = ContentBlockerRulesBuilder(trackerData: nextiOSTDS).buildRules()

let data = try JSONEncoder().encode(rules)
let ruleList = String(data: data, encoding: .utf8)!

var store: WKContentRuleListStore!

let warmUpExpectation = expectation(description: "Warmed up")

DispatchQueue.main.async {
store = WKContentRuleListStore(url: FileManager.default.temporaryDirectory)
store.compileContentRuleList(forIdentifier: UUID().uuidString, encodedContentRuleList: ruleList) { _, error in
XCTAssertNil(error)
warmUpExpectation.fulfill()
}
}
wait(for: [warmUpExpectation], timeout: 40)

measure {
let time = CACurrentMediaTime()
let expectation = expectation(description: "Compiled")

store.compileContentRuleList(forIdentifier: UUID().uuidString, encodedContentRuleList: ruleList) { _, error in
XCTAssertNil(error)

Thread.sleep(forTimeInterval: 1)

expectation.fulfill()
}

wait(for: [expectation], timeout: 40)
print("Compiled in \(CACurrentMediaTime() - time)")
}
}
}

0 comments on commit 0d6346a

Please sign in to comment.