]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blob - Server/tests/client_test.cpp
Se implementa una señal entre Thread con Glib::Dispatch .. no se si soluciona el...
[z.facultad/75.42/plaqui.git] / Server / tests / client_test.cpp
1 // vim: set noexpandtab tabstop=4 shiftwidth=4:
2 //----------------------------------------------------------------------------
3 //                                  PlaQui
4 //----------------------------------------------------------------------------
5 // This file is part of PlaQui.
6 //
7 // PlaQui is free software; you can redistribute it and/or modify it under the
8 // terms of the GNU General Public License as published by the Free Software
9 // Foundation; either version 2 of the License, or (at your option) any later
10 // version.
11 //
12 // PlaQui is distributed in the hope that it will be useful, but WITHOUT ANY
13 // WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14 // FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
15 // details.
16 //
17 // You should have received a copy of the GNU General Public License along
18 // with PlaQui; if not, write to the Free Software Foundation, Inc., 59 Temple
19 // Place, Suite 330, Boston, MA  02111-1307  USA
20 //----------------------------------------------------------------------------
21 // Creado:  jue nov 13 00:53:38 ART 2003
22 // Autores: Leandro Lucarella <llucare@fi.uba.ar>
23 //----------------------------------------------------------------------------
24 //
25 // $Id$
26 //
27
28 #include "plaqui/server/controlclient.h"
29 #include "plaqui/server/string.h"
30 #include <iostream>
31 #include <sstream>
32 #include <exception>
33 #include <vector>
34
35 using namespace std;
36 using namespace PlaQui::Server;
37
38 ControlClient* client = NULL;
39
40 void on_finished(void) {
41         client = NULL;
42 }
43
44 void on_connected(void) {
45         cout << "   Conectado! :-)" << endl;
46 }
47
48 void on_ok_received(const string& body) {
49         cout << "   Respuesta recibida: OK! :-D" << endl;
50         cout << "       Body: " << body << endl;
51 }
52
53 void on_frame_received(const string& frame) {
54         cout << "   Frame recibido! :-D" << endl;
55         cout << frame << endl;
56 }
57
58 void on_error_received(unsigned code) {
59         cout << "   Respuesta recibida: Error nro " << code << "! :-(" << endl;
60 }
61
62 int main(int argc, char* argv[]) {
63
64         // Termina con mas informacion si hay una excepcion no manejada.
65         set_terminate (__gnu_cxx::__verbose_terminate_handler);
66
67         // Mensaje de bienvenida.
68         cout << "Client test. Modo de uso: " << endl;
69         cout << "\t" << argv[0] << " [host] [port]" << endl;
70         cout << "Luego se envian comandos con el siguiente formato:" << endl;
71         cout << "\t <destino> <comando> [<arg 1>] [<arg 2>] [...] [<arg N>]" << endl;
72
73         // Parámetros.
74         string host = "localhost";
75         if (argc > 1) {
76                 // Obtengo host.
77                 host = argv[1];
78         }
79         Connection::Port port = 7522;
80         if (argc > 2) {
81                 // Obtengo puerto.
82                 stringstream str(argv[2]);
83                 str >> port;
84         }
85
86         // Inicializa threads.
87         Glib::thread_init();
88
89         try {
90                 // Corre el cliente.
91                 client = new ControlClient(host, port);
92                 client->signal_finished().connect(SigC::slot(on_finished));
93                 client->signal_connected().connect(SigC::slot(on_connected));
94                 client->signal_ok_received().connect(SigC::slot(on_ok_received));
95                 client->signal_error_received().connect(SigC::slot(on_error_received));
96                 client->signal_frame_received().connect(SigC::slot(on_frame_received));
97                 client->run();
98                 char buf[BUFSIZ];
99                 while (cin.getline(buf, BUFSIZ)) {
100                         if (!client) {
101                                 break;
102                         }
103                         vector<string> v = String(buf).split(' ');
104                         switch (v.size()) {
105                                 case 0:
106                                         client->send(Command());
107                                         break;
108                                 case 1:
109                                         client->send(Command(v[0]));
110                                         break;
111                                 case 2:
112                                         client->send(Command(v[0], v[1]));
113                                         break;
114                                 default:
115                                         Command cmd(v[0], v[1]);
116                                         v.erase(v.begin(), v.begin() + 2);
117                                         cmd.set_args(v);
118                                         client->send(cmd);
119                                         break;
120                         }
121                 }
122         } catch (const sockerr& e) {
123                 cerr << "Socket Error: " << e.operation() << " | serrno = "
124                         << e.serrno() << " | errstr = " << e.errstr() << endl;
125                 if (e.io()) {
126                         cerr << "Es: non-blocking and interrupt io recoverable error."
127                                 << endl;
128                 } else if (e.arg()) {
129                         cerr <<  "Es: incorrect argument supplied. recoverable error."
130                                 << endl;
131                 } else if (e.op()) {
132                         cerr << "Es: operational error. recovery difficult." << endl;
133                 } else if (e.conn()) {
134                         cerr << "Es: connection error." << endl;
135                 } else if (e.addr()) {
136                         cerr << "Es: address error." << endl;
137                 } else if (e.benign()) {
138                         cerr << "Es: recoverable read/write error like EINTR etc." << endl;
139                 }
140         } catch (const exception& e) {
141                 cerr << "Error: " << e.what() << endl;
142         } catch (const char* e) {
143                 cerr << "Error: " << e << endl;
144         } catch (...) {
145                 cerr << "Error desconocido!" << endl;
146         }
147
148         return 0;
149 }