# Copyright 2025 Google LLC # # 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 asyncio import time import warnings import agent from dotenv import load_dotenv from google.adk import Runner from google.adk.agents.run_config import RunConfig from google.adk.artifacts import InMemoryArtifactService from google.adk.cli.utils import logs from google.adk.sessions import InMemorySessionService from google.adk.sessions import Session from google.genai import types load_dotenv(override=True) warnings.filterwarnings('ignore', category=UserWarning) logs.log_to_tmp_folder() async def main(): app_name = 'my_app' user_id_1 = 'user1' session_service = InMemorySessionService() artifact_service = InMemoryArtifactService() runner = Runner( app_name=app_name, agent=agent.root_agent, artifact_service=artifact_service, session_service=session_service, ) session_11 = session_service.create_session( app_name=app_name, user_id=user_id_1 ) total_prompt_tokens = 0 total_candidate_tokens = 0 total_tokens = 0 async def run_prompt(session: Session, new_message: str): nonlocal total_prompt_tokens nonlocal total_candidate_tokens nonlocal total_tokens content = types.Content( role='user', parts=[types.Part.from_text(text=new_message)] ) print('** User says:', content.model_dump(exclude_none=True)) async for event in runner.run_async( user_id=user_id_1, session_id=session.id, new_message=content, ): if event.content.parts and event.content.parts[0].text: print(f'** {event.author}: {event.content.parts[0].text}') if event.usage_metadata: total_prompt_tokens += event.usage_metadata.prompt_token_count or 0 total_candidate_tokens += ( event.usage_metadata.candidates_token_count or 0 ) total_tokens += event.usage_metadata.total_token_count or 0 print( 'Turn tokens:' f' {event.usage_metadata.total_token_count} (prompt={event.usage_metadata.prompt_token_count},' f' candidates={event.usage_metadata.candidates_token_count})' ) print( f'Session tokens: {total_tokens} (prompt={total_prompt_tokens},' f' candidates={total_candidate_tokens})' ) start_time = time.time() print('Start time:', start_time) print('------------------------------------') await run_prompt(session_11, 'Hi') await run_prompt(session_11, 'Roll a die with 100 sides') print( await artifact_service.list_artifact_keys( app_name=app_name, user_id=user_id_1, session_id=session_11.id ) ) end_time = time.time() print('------------------------------------') print('End time:', end_time) print('Total time:', end_time - start_time) if __name__ == '__main__': asyncio.run(main())