| # Copyright (C) 2024 The Android Open Source Project |
| # |
| # 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. |
| |
| import os |
| import perfetto.bigtrace.api |
| import subprocess |
| import unittest |
| |
| from perfetto.common.exceptions import PerfettoException |
| |
| # To run this test you must setup the a GCS bucket and a GKE cluster setup with |
| # Bigtrace running. |
| # This should be executed within the same VPC to allow for connection to the |
| # service. |
| |
| # This should be replaced with the name of the trace bucket you have deployed |
| # on. |
| TRACE_BUCKET_NAME = "trace_example_bucket" |
| # This should be loaded in the top level of the bucket. |
| TRACE_PATH = "android_startup_real.perfetto_trace" |
| # This should be replaced with the address of the Orchestrator service for the |
| # Bigtrace service. |
| ORCHESTRATOR_ADDRESS = "127.0.0.1:5052" |
| # This can be changed if testing on a different trace. |
| QUERY_RESULT_COUNT = 339338 |
| |
| |
| class BigtraceGcsTest(unittest.TestCase): |
| |
| def setUpClass(self): |
| self.client = perfetto.bigtrace.api.Bigtrace( |
| wait_for_ready_for_testing=True) |
| |
| def test_valid_trace(self): |
| traces = [f"/gcs/{TRACE_BUCKET_NAME}/o/{TRACE_PATH}"] |
| result = self.client.query(traces, "SELECT count(1) as count FROM slice") |
| self.assertEqual(result['count'].iloc[0], QUERY_RESULT_COUNT) |
| |
| def test_invalid_trace(self): |
| with self.assertRaises(PerfettoException): |
| traces = [f"/gcs/{TRACE_BUCKET_NAME}/o/badpath"] |
| result = self.client.query(traces, "SELECT count(1) as count FROM slice") |
| |
| def test_invalid_bucket(self): |
| with self.assertRaises(PerfettoException): |
| traces = [f"/gcs//o/{TRACE_PATH}"] |
| result = self.client.query(traces, "SELECT count(1) as count FROM slice") |