import time import logging from examples.prerun import client if __name__ == "__main__": assistant = client.beta.assistants.create( name="Assistant Demo", instructions="you are a personal assistant, reply 'hello' to user", model="gpt-3.5-turbo-1106", ) logging.info("=====> : %s\n", assistant) thread = client.beta.threads.create() logging.info("=====> : %s\n", thread) message = client.beta.threads.messages.create( thread_id=thread.id, role="user", content="hello", ) logging.info("=====> : %s\n", message) run = client.beta.threads.runs.create( thread_id=thread.id, assistant_id=assistant.id, instructions="", ) logging.info("=====> : %s\n", run) logging.info("checking assistant status. \n") while True: run = client.beta.threads.runs.retrieve(thread_id=thread.id, run_id=run.id) run_steps = client.beta.threads.runs.steps.list(run_id=run.id, thread_id=thread.id).data for run_step in run_steps: logging.info("=====> : %s\n", run_step) if run.status == "completed": messages = client.beta.threads.messages.list(thread_id=thread.id) logging.info("=====> messages:") for message in messages: assert message.content[0].type == "text" logging.info("%s", {"role": message.role, "message": message.content[0].text.value}) # delete asst client.beta.assistants.delete(assistant.id) break elif run.status == "failed": logging.error("run failed %s\n", run.last_error) break else: logging.info("in progress...\n") time.sleep(5)