xref: /aosp_15_r20/external/perfetto/python/test/bigtrace_gcs_manualtest.py (revision 6dbdd20afdafa5e3ca9b8809fa73465d530080dc)
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