blob: c4311da64d582022af4d62a22b78d5a85d088af9 [file] [log] [blame]
#!/usr/bin/env python3
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you 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 time
from teaclave import TaskStatus
from utils import USER_ID, USER_PASSWORD, connect_authentication_service, connect_frontend_service, PlatformAdmin
class MesaPyEchoExample:
def __init__(self, user_id, user_password):
self.user_id = user_id
self.user_password = user_password
def deadloop(self, payload_file="mesapy_deadloop_payload.py"):
with connect_authentication_service() as client:
print(f"[+] {self.user_id} login")
token = client.user_login(self.user_id, self.user_password)
client = connect_frontend_service()
metadata = {"id": self.user_id, "token": token}
client.metadata = metadata
print("[+] registering function")
with open(payload_file, "rb") as f:
payload = f.read()
function_id = client.register_function(
name="mesapy-deadloop",
description="A deadloop function to test task cancellation",
executor_type="python",
payload=list(payload),
arguments=[])
print("[+] creating task")
task_id = client.create_task(function_id=function_id,
function_arguments={},
executor="mesapy")
print("[+] invoking task")
client.invoke_task(task_id)
print("[+] waiting task")
while True:
task = client.get_task(task_id)
time.sleep(5)
if task['status'] == TaskStatus.Running:
break
print("[+] canceling task")
client.cancel_task(task_id)
time.sleep(5)
print("[+] getting result")
result = client.get_task(task_id)
if result["status"] != TaskStatus.Canceled:
print("[+] Task is not canceled, cancel again")
try:
client.cancel_task(task_id)
except Exception as e:
# this happens when the task has already been canceled
print(f"[-] cancel task failed, reason: {str(e)}")
try:
result = client.get_task_result(task_id)
except Exception as e:
# this is expected, since the task is cancelled
print(f"[-] getting result failed, reason: {str(e)}")
def main():
example = MesaPyEchoExample(USER_ID, USER_PASSWORD)
example.deadloop()
if __name__ == '__main__':
main()