]> git.llucax.com Git - z.facultad/75.42/plaqui.git/blob - Server/tests/client_test.cpp
0ab975bac78fc414ec93298ae1cb679c6c4fbd18
[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_error_received(unsigned code) {
54         cout << "   Respuesta recibida: Error nro " << code << "! :-(" << endl;
55 }
56
57 int main(int argc, char* argv[]) {
58
59         // Termina con mas informacion si hay una excepcion no manejada.
60         set_terminate (__gnu_cxx::__verbose_terminate_handler);
61
62         // Mensaje de bienvenida.
63         cout << "Client test. Modo de uso: " << endl;
64         cout << "\t" << argv[0] << " [host] [port]" << endl;
65         cout << "Luego se envian comandos con el siguiente formato:" << endl;
66         cout << "\t <destino> <comando> [<arg 1>] [<arg 2>] [...] [<arg N>]" << endl;
67
68         // Parámetros.
69         string host = "localhost";
70         if (argc > 1) {
71                 // Obtengo host.
72                 host = argv[1];
73         }
74         Connection::Port port = 7522;
75         if (argc > 2) {
76                 // Obtengo puerto.
77                 stringstream str(argv[2]);
78                 str >> port;
79         }
80
81         // Inicializa threads.
82         Glib::thread_init();
83
84         try {
85                 // Corre el cliente.
86                 client = new ControlClient(host, port);
87                 client->signal_finished().connect(SigC::slot(on_finished));
88                 client->signal_connected().connect(SigC::slot(on_connected));
89                 client->signal_ok_received().connect(SigC::slot(on_ok_received));
90                 client->signal_error_received().connect(SigC::slot(on_error_received));
91                 client->run();
92                 char buf[BUFSIZ];
93                 while (cin.getline(buf, BUFSIZ)) {
94                         if (!client) {
95                                 break;
96                         }
97                         vector<string> v = String(buf).split(' ');
98                         switch (v.size()) {
99                                 case 0:
100                                         client->send(Command());
101                                         break;
102                                 case 1:
103                                         client->send(Command(v[0]));
104                                         break;
105                                 case 2:
106                                         client->send(Command(v[0], v[1]));
107                                         break;
108                                 default:
109                                         Command cmd(v[0], v[1]);
110                                         v.erase(v.begin(), v.begin() + 2);
111                                         cmd.set_args(v);
112                                         client->send(cmd);
113                                         break;
114                         }
115                 }
116         } catch (const sockerr& e) {
117                 cerr << "Socket Error: " << e.operation() << " | serrno = "
118                         << e.serrno() << " | errstr = " << e.errstr() << endl;
119                 if (e.io()) {
120                         cerr << "Es: non-blocking and interrupt io recoverable error."
121                                 << endl;
122                 } else if (e.arg()) {
123                         cerr <<  "Es: incorrect argument supplied. recoverable error."
124                                 << endl;
125                 } else if (e.op()) {
126                         cerr << "Es: operational error. recovery difficult." << endl;
127                 } else if (e.conn()) {
128                         cerr << "Es: connection error." << endl;
129                 } else if (e.addr()) {
130                         cerr << "Es: address error." << endl;
131                 } else if (e.benign()) {
132                         cerr << "Es: recoverable read/write error like EINTR etc." << endl;
133                 }
134         } catch (const exception& e) {
135                 cerr << "Error: " << e.what() << endl;
136         } catch (const char* e) {
137                 cerr << "Error: " << e << endl;
138         } catch (...) {
139                 cerr << "Error desconocido!" << endl;
140         }
141
142         return 0;
143 }