1*6dbdd20aSAndroid Build Coastguard Worker# Copyright (C) 2024 The Android Open Source Project 2*6dbdd20aSAndroid Build Coastguard Worker# 3*6dbdd20aSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); 4*6dbdd20aSAndroid Build Coastguard Worker# you may not use this file except in compliance with the License. 5*6dbdd20aSAndroid Build Coastguard Worker# You may obtain a copy of the License at 6*6dbdd20aSAndroid Build Coastguard Worker# 7*6dbdd20aSAndroid Build Coastguard Worker# http://www.apache.org/licenses/LICENSE-2.0 8*6dbdd20aSAndroid Build Coastguard Worker# 9*6dbdd20aSAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software 10*6dbdd20aSAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS, 11*6dbdd20aSAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*6dbdd20aSAndroid Build Coastguard Worker# See the License for the specific language governing permissions and 13*6dbdd20aSAndroid Build Coastguard Worker# limitations under the License. 14*6dbdd20aSAndroid Build Coastguard Worker 15*6dbdd20aSAndroid Build Coastguard Workerimport os 16*6dbdd20aSAndroid Build Coastguard Workerimport perfetto.bigtrace.api 17*6dbdd20aSAndroid Build Coastguard Workerimport subprocess 18*6dbdd20aSAndroid Build Coastguard Workerimport unittest 19*6dbdd20aSAndroid Build Coastguard Worker 20*6dbdd20aSAndroid Build Coastguard Workerfrom perfetto.common.exceptions import PerfettoException 21*6dbdd20aSAndroid Build Coastguard Worker 22*6dbdd20aSAndroid Build Coastguard Worker# To run this test you must setup the a GCS bucket and a GKE cluster setup with 23*6dbdd20aSAndroid Build Coastguard Worker# Bigtrace running. 24*6dbdd20aSAndroid Build Coastguard Worker# This should be executed within the same VPC to allow for connection to the 25*6dbdd20aSAndroid Build Coastguard Worker# service. 26*6dbdd20aSAndroid Build Coastguard Worker 27*6dbdd20aSAndroid Build Coastguard Worker# This should be replaced with the name of the trace bucket you have deployed 28*6dbdd20aSAndroid Build Coastguard Worker# on. 29*6dbdd20aSAndroid Build Coastguard WorkerTRACE_BUCKET_NAME = "trace_example_bucket" 30*6dbdd20aSAndroid Build Coastguard Worker# This should be loaded in the top level of the bucket. 31*6dbdd20aSAndroid Build Coastguard WorkerTRACE_PATH = "android_startup_real.perfetto_trace" 32*6dbdd20aSAndroid Build Coastguard Worker# This should be replaced with the address of the Orchestrator service for the 33*6dbdd20aSAndroid Build Coastguard Worker# Bigtrace service. 34*6dbdd20aSAndroid Build Coastguard WorkerORCHESTRATOR_ADDRESS = "127.0.0.1:5052" 35*6dbdd20aSAndroid Build Coastguard Worker# This can be changed if testing on a different trace. 36*6dbdd20aSAndroid Build Coastguard WorkerQUERY_RESULT_COUNT = 339338 37*6dbdd20aSAndroid Build Coastguard Worker 38*6dbdd20aSAndroid Build Coastguard Worker 39*6dbdd20aSAndroid Build Coastguard Workerclass BigtraceGcsTest(unittest.TestCase): 40*6dbdd20aSAndroid Build Coastguard Worker 41*6dbdd20aSAndroid Build Coastguard Worker def setUpClass(self): 42*6dbdd20aSAndroid Build Coastguard Worker self.client = perfetto.bigtrace.api.Bigtrace( 43*6dbdd20aSAndroid Build Coastguard Worker wait_for_ready_for_testing=True) 44*6dbdd20aSAndroid Build Coastguard Worker 45*6dbdd20aSAndroid Build Coastguard Worker def test_valid_trace(self): 46*6dbdd20aSAndroid Build Coastguard Worker traces = [f"/gcs/{TRACE_BUCKET_NAME}/o/{TRACE_PATH}"] 47*6dbdd20aSAndroid Build Coastguard Worker result = self.client.query(traces, "SELECT count(1) as count FROM slice") 48*6dbdd20aSAndroid Build Coastguard Worker self.assertEqual(result['count'].iloc[0], QUERY_RESULT_COUNT) 49*6dbdd20aSAndroid Build Coastguard Worker 50*6dbdd20aSAndroid Build Coastguard Worker def test_invalid_trace(self): 51*6dbdd20aSAndroid Build Coastguard Worker with self.assertRaises(PerfettoException): 52*6dbdd20aSAndroid Build Coastguard Worker traces = [f"/gcs/{TRACE_BUCKET_NAME}/o/badpath"] 53*6dbdd20aSAndroid Build Coastguard Worker result = self.client.query(traces, "SELECT count(1) as count FROM slice") 54*6dbdd20aSAndroid Build Coastguard Worker 55*6dbdd20aSAndroid Build Coastguard Worker def test_invalid_bucket(self): 56*6dbdd20aSAndroid Build Coastguard Worker with self.assertRaises(PerfettoException): 57*6dbdd20aSAndroid Build Coastguard Worker traces = [f"/gcs//o/{TRACE_PATH}"] 58*6dbdd20aSAndroid Build Coastguard Worker result = self.client.query(traces, "SELECT count(1) as count FROM slice") 59