]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blob - Server/tests/client_test.cpp
Retoques finales:
[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 <exception>
32 #include <vector>
33
34 using namespace std;
35 using namespace PlaQui::Server;
36
37 ControlClient* client = NULL;
38
39 void on_error(const Runnable::Error& code, const string& desc) {
40         cerr << "--------------------------------------------------------" << endl;
41         cerr << "Error en el cliente:" << endl;
42         cerr << "Código: " << code << endl;
43         cerr << "Descripción: " << desc << endl;
44         cerr << "--------------------------------------------------------" << endl;
45 }
46
47 void on_finished(void) {
48         client = NULL;
49 }
50
51 void on_connected(void) {
52         cout << "   Conectado! :-)" << endl;
53 }
54
55 void on_ok_received(const string& body) {
56         cout << "   Respuesta recibida: OK! :-D" << endl;
57         cout << "       Body: " << body << endl;
58 }
59
60 void on_frame_received(const string& frame) {
61         cout << "   Frame recibido! :-D" << endl;
62         cout << frame << endl;
63 }
64
65 void on_error_received(unsigned code) {
66         cout << "   Respuesta recibida: Error nro " << code << "! :-(" << endl;
67 }
68
69 int main(int argc, char* argv[]) {
70
71         // Termina con mas informacion si hay una excepcion no manejada.
72         set_terminate (__gnu_cxx::__verbose_terminate_handler);
73
74         // Mensaje de bienvenida.
75         cout << "Client test. Modo de uso: " << endl;
76         cout << "\t" << argv[0] << " [host] [port]" << endl;
77         cout << "Luego se envian comandos con el siguiente formato:" << endl;
78         cout << "\t <destino> <comando> [<arg 1>] [<arg 2>] [...] [<arg N>]" << endl;
79
80         // Parámetros.
81         string host = "localhost";
82         if (argc > 1) {
83                 // Obtengo host.
84                 host = argv[1];
85         }
86         // Obtengo puerto.
87         Connection::Port port = 7522;
88         if (argc > 2) {
89                 to(argv[2], port);
90         }
91
92         // Inicializa threads.
93         Glib::thread_init();
94
95         try {
96                 // Corre el cliente.
97                 client = new ControlClient(host, port);
98                 client->signal_error().connect(SigC::slot(on_error));
99                 client->signal_finished().connect(SigC::slot(on_finished));
100                 client->signal_connected().connect(SigC::slot(on_connected));
101                 client->signal_ok_received().connect(SigC::slot(on_ok_received));
102                 client->signal_error_received().connect(SigC::slot(on_error_received));
103                 client->signal_frame_received().connect(SigC::slot(on_frame_received));
104                 client->run();
105                 char buf[BUFSIZ];
106                 while (cin.getline(buf, BUFSIZ)) {
107                         if (!client) {
108                                 break;
109                         }
110                         vector<string> v = String(buf).split(' ');
111                         switch (v.size()) {
112                                 case 0:
113                                         client->send(Command());
114                                         break;
115                                 case 1:
116                                         client->send(Command(v[0]));
117                                         break;
118                                 case 2:
119                                         client->send(Command(v[0], v[1]));
120                                         break;
121                                 default:
122                                         Command cmd(v[0], v[1]);
123                                         v.erase(v.begin(), v.begin() + 2);
124                                         cmd.set_args(v);
125                                         client->send(cmd);
126                                         break;
127                         }
128                 }
129         } catch (const sockerr& e) {
130                 cerr << "Socket Error: " << e.operation() << " | serrno = "
131                         << e.serrno() << " | errstr = " << e.errstr() << endl;
132                 if (e.io()) {
133                         cerr << "Es: non-blocking and interrupt io recoverable error."
134                                 << endl;
135                 } else if (e.arg()) {
136                         cerr <<  "Es: incorrect argument supplied. recoverable error."
137                                 << endl;
138                 } else if (e.op()) {
139                         cerr << "Es: operational error. recovery difficult." << endl;
140                 } else if (e.conn()) {
141                         cerr << "Es: connection error." << endl;
142                 } else if (e.addr()) {
143                         cerr << "Es: address error." << endl;
144                 } else if (e.benign()) {
145                         cerr << "Es: recoverable read/write error like EINTR etc." << endl;
146                 }
147         } catch (const exception& e) {
148                 cerr << "Error: " << e.what() << endl;
149         } catch (const char* e) {
150                 cerr << "Error: " << e << endl;
151         } catch (...) {
152                 cerr << "Error desconocido!" << endl;
153         }
154
155         return 0;
156 }