Blame view

src/core/pyros_django/agent/AgentTriton.py 5.55 KB
22967191   Alexis Koralewski   Add AgentTriton
1
2
3
4
5
#!/usr/bin/env python3


import subprocess
import sys
21843a6b   Alexis Koralewski   Add argparse & ne...
6
import os, argparse
22967191   Alexis Koralewski   Add AgentTriton
7
8
9
10
11
12
13
##import utils.Logger as L

pwd = os.environ['PROJECT_ROOT_PATH']
if pwd not in sys.path:
    sys.path.append(pwd)

##from .Agent import Agent
e848fbef   Alexis Koralewski   Change import of ...
14
from src.core.pyros_django.agent.Agent import Agent, build_agent
22967191   Alexis Koralewski   Add AgentTriton
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33

##log = L.setupLogger("AgentXTaskLogger", "AgentX")



class AgentTriton(Agent):

    # FOR TEST ONLY
    # Run this agent in simulator mode
    TEST_MODE = False
    # Run the assertion tests at the end
    TEST_WITH_FINAL_TEST = False
    #TEST_MAX_DURATION_SEC = None
    TEST_MAX_DURATION_SEC = 100
    # Who should I send commands to ?
    TEST_COMMANDS_DEST = "myself"
    #TEST_COMMANDS_DEST = "AgentB"
    # Scenario to be executed

baada9d5   Etienne Pallier   New PRIO CMD mana...
34
35
36
    _AGENT_SPECIFIC_COMMANDS = {
        # Format : “cmd_name” : (timeout, exec_mode)
        
5bbf88b6   Etienne Pallier   ajout Specific Co...
37
        "do_process_image" : (10, Agent.EXEC_MODE.SEQUENTIAL, ''),
baada9d5   Etienne Pallier   New PRIO CMD mana...
38
    }    
22967191   Alexis Koralewski   Add AgentTriton
39

0bcd6dd5   Etienne Pallier   renamed Agent met...
40
    _TEST_COMMANDS_LIST = [
baada9d5   Etienne Pallier   New PRIO CMD mana...
41
42
        (True, "self do_process_image i.fit", 200, None, Agent.CMD_STATUS.CMD_EXECUTED),
        (True, "self do_stop", 500, "STOPPING", Agent.CMD_STATUS.CMD_EXECUTED),
22967191   Alexis Koralewski   Add AgentTriton
43
44
45
46
47
48
49
    ]
    """
    =================================================================
        FUNCTIONS RUN INSIDE MAIN THREAD
    =================================================================
    """

30eeadc1   Etienne Pallier   cleanup
50
    # @Override
22967191   Alexis Koralewski   Add AgentTriton
51
52
53
54
55
56
57
58
59
    '''
    #def __init__(self, name:str=None, config_filename=None, RUN_IN_THREAD=True):
    def __init__(self, config_filename=None):
        ##if name is None: name = self.__class__.__name__
        #super().__init__(name, config_filename, RUN_IN_THREAD)
        super().__init__(config_filename)
        #self._log.print(f"init done for {name}")
        self._log.print("init done")
    '''
e0c74bd8   Alexis Koralewski   fix simulated_com...
60
    def __init__(self, name:str=None,simulated_computer=None):
22967191   Alexis Koralewski   Add AgentTriton
61
62
        if name is None:
            name = self.__class__.__name__
e0c74bd8   Alexis Koralewski   fix simulated_com...
63
        super().__init__(simulated_computer=simulated_computer)
22967191   Alexis Koralewski   Add AgentTriton
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
        #super().__init__(RUN_IN_THREAD)        


    def shell_source(self,script):
        """
        Sometime you want to emulate the action of "source" in bash,
        settings some environment variables. Here is a way to do it.
        """
        
        pipe = subprocess.Popen(". %s && env -0" % script, stdout=subprocess.PIPE, shell=True)
        output = pipe.communicate()[0].decode('utf-8')
        output = output[:-1] # fix for index out for range in 'env[ line[0] ] = line[1]'

        env = {}
        # split using null char
        for line in output.split('\x00'):
            line = line.split( '=', 1)
            # print(line)
            env[ line[0] ] = line[1]

        os.environ.update(env)

30eeadc1   Etienne Pallier   cleanup
86
    # @Override
0bcd6dd5   Etienne Pallier   renamed Agent met...
87
    def _init(self):
22967191   Alexis Koralewski   Add AgentTriton
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
        triton_folder = self.get_config().get_agent_information(self.get_config().unit_name,self.name)["path"]
        triton_folder_abs_path = pwd + "/" + triton_folder + "/"
        self.triton_folder_abs_path = triton_folder_abs_path

        if not os.path.exists(triton_folder_abs_path+"output/"):
            os.makedirs(triton_folder_abs_path+"output/")
        if not os.path.exists(triton_folder_abs_path+"input/"):
            os.makedirs(triton_folder_abs_path+"input/")
        self.output_folder = triton_folder_abs_path+"output/"
        self.input_folder = triton_folder_abs_path+"input/"
        self.shell_source(triton_folder_abs_path+'triton/Triton_ubuntu_20.04/Triton_3.1.2/conf/configure.sh')
        #main_cmd = triton_folder_abs_path + "triton/Triton_ubuntu_20.04/Triton_3.1.2/bin/triton -i " + triton_folder_abs_path + "input/" + " -s " + triton_folder_abs_path + "output/"
        #subprocess.Popen(main_cmd)
        # --- Set the mode according the startmode value
        ##agent_alias = self.__class__.__name__
        ##self.set_mode_from_config(agent_alias)

    def do_process_image(self, image_name:str):
        image_path = self.input_folder + image_name
        output_file_name = image_name.split(".")[0] + ".txt"
        output_file_path = self.output_folder + output_file_name
        if os.path.exists(image_path):
            main_cmd = self.triton_folder_abs_path + "triton/Triton_ubuntu_20.04/Triton_3.1.2/bin/triton -i " + image_path + " -s " + output_file_path

            subprocess.Popen(main_cmd,shell=True)
        else:  
            print(f"Can't find image {image_path}")
    #@override
0bcd6dd5   Etienne Pallier   renamed Agent met...
116
    def _main_loop_start(self):
22967191   Alexis Koralewski   Add AgentTriton
117
118
119
        print("LOOP START")

    #@override
0bcd6dd5   Etienne Pallier   renamed Agent met...
120
    def _main_loop_end(self):
22967191   Alexis Koralewski   Add AgentTriton
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
        print("LOOP END");

    '''
    # @override
    def load_config(self):
        super().load_config()
    '''

    '''
    # @override
    def update_survey(self):
        super().update_survey()
    '''

    '''
    # @override
    def get_next_command(self):
        return super().get_next_command()
    '''

    # @override
    def do_log(self):
        super().do_log()

    # @override
0bcd6dd5   Etienne Pallier   renamed Agent met...
146
    def _do_things_before_exit(self, stopper_agent_name=None):
22967191   Alexis Koralewski   Add AgentTriton
147
148
149
150
151
152
153
154
        print("AgentBasic fait quelques trucs à lui avant de stopper...")

"""
=================================================================
    MAIN FUNCTION
=================================================================
"""
if __name__ == "__main__":
21843a6b   Alexis Koralewski   Add argparse & ne...
155
156
157
158
159
    parser = argparse.ArgumentParser(description='Start a agentSST.')
    parser.add_argument("--computer",dest="computer",help='Launch agent with simulated computer hostname',action="store")
    parser.add_argument("-t", action="store_true")
    args = vars(parser.parse_args())
    agent = build_agent(AgentTriton,param_constr=args)
22967191   Alexis Koralewski   Add AgentTriton
160
161
162
163
164
165
166
167
168

    '''
    TEST_MODE, configfile = extract_parameters()
    #agent = AgentX()
    agent = AgentA("AgentA", configfile, RUN_IN_THREAD)
    agent.setSimulatorMode(TEST_MODE)
    print(agent)
    '''
    agent.run()