Passa al contingut principal

Handlers d'errors en node.js quina bogeria ;)

Després de dos dies tornat-me varilla amb els handlers d'error en node.js, al final, quasi de casualitat he descobert que passa. Imaginem que vull connectar a una base de dades:

function doLogin(){
  var client = mysql.createConnection('mysql://'+user + ':'+pass+'@'+server+'/'+database);
  client.connect();
 }//function doLogin


La funció connect pot fallar en cas que els paràmetres siguen incorrectes, no hi haja connexió... si eixe error no és capturat, tanca el programa (tancant el servidor). Primer proví amb try catch, herència d'altres llenguatges no tant moderns ;) i no, no vaig aconseguir capturar l'error. Per tant vaig llegir que la millor cosa que podia fer en javascript (node.js) era afegir  una funció callback (que s'executa en cas d'error, i passada com a paràmetre). La funció ha de ser algo així:

 function errResult(err,result){
  if (err != null) {
         berror = true;
   }
  else{
       berror = false;
  }
 }//function errResult


on en err estarà el missatge d'error i berror serà una variable d'error que podrem examinar si hi ha havut error o no al login. canviarem el codi de doLogin per:

client.connect(errResult);

i tindrem el codi següent per a veure si s'ha produït el login correctament:

doLogin()
if (!berror) {//login OK
    res= "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?><resposta>OK</resposta>";
  }
  else{//error login
    res = cadena_error_login_ini + error_missatge +cadena_error_login_fi;
  }

La lògica ens dius que quan cridem a doLogin, esta cridarà a errResult i actualitzarà la variable berror en el cas pertinent. Això pensava jo i res més lluny de la realitat. La cosa és que posara les dades que posara sempre em donava OK. Com ja he dit duc un cap de setmana fent proves i no hi ha habut manera. Al final he decidit fer un log de totes les accions a veure que passava:

 function doLogin(){
  var client = mysql.createConnection('mysql://'+user + ':'+pass+'@'+server+'/'+database);
  console.log("Abans de connect");
  client.connect(errResult);
  console.log("Després de connect");
 }//function doLogin


function errResult(err,result){
  if (err != null) {
     error_missatge=err;
     berror = true;
     console.log("Ha havut un error però s\'haurà capturat?");
   }
  else{
    error_missatge = "";
    berror = false;
  }
  console.log(berror);
 }//function errResult


I en la funció del servidor (hi ha més coses però les estic omitint per no fer més llarg el copy & paste):

doLogin();
  console.log("doLogin");
  if (!berror) {//login OK
    res= "<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?><resposta>OK</resposta>";
  }
  else{//error login
    res = cadena_error_login_ini + error_missatge +cadena_error_login_fi;
  }

 response.end(res);
console.log("final servidor");





L'eixida de consola deuria de ser:
Abans de connect
Ha havut un error però s'haurà capturat?
 Després de connect
doLogin
final servidor





Però no, resulta ser:

Abans de connect
Després de connect
doLogin
final servidor
Ha havut un error però s'haurà capturat?

Cosa que ens indica que la funció callback de maneig d'error s'execute una vegada ha acabat la funció principal del servidor. Per tant este model no ens val per capturar l'error. Caldrà canviar el model, pròximament posaré la solució al problema ;)

Comentaris

Entrades populars d'aquest blog

Anàlisi d'eleccions estatals

Estes eleccions (estatals) han marcat una important fita electoral en la comparació de forces, sobretot en l'eix esquerra dreta. Eixa ha segut l'agenda política, marcada, en la meua opinió, pel PSOE. La campanya ha consistit en la por a VOX i a que torne la dreta ( ja fa molts anys que gasten eixe argument), i esta vegada pareix que VOX ha segut una amenaça suficient per mobilitzar el vot on no s'ha sabut interpretar que tot era una campanya dirigida.
En especial, per a Compromís, ha segut un resultat, què, per ser políticament correcte, no a assolit els objectius: recordem que es plantejava traure'n 5 diputats i tindre grup parlamentari propi. El resultat ha segut el que tots sabem, 1 diputat.

Alguns en Compromís (i fora) atribueixen el resultat al no haver pacte amb Podemos. Però aquest partit, ha perdut un 25% de vots i un 40% dels diputats (difícil de fer els càlculs exactes per tal de destriar les confluències). Per tant, ajuntar-se amb un partit a la baixa (mentr…

Comparativa dels Sistemes Polítics Espanyol, Valencià i d'un partit polític. (II)

El Poder Executiu En l’Estat Espanyol, el poder executiu real bé donat pel President del Govern. Aquest triarà els Vicepresidents, Ministres, etc (directa o indirectament, alguns alts càrrecs els triaran els corresponent Ministres). No hi ha cap limitació al respecte la persona elegida (no ha de ser diputada, ni cap límit de formació, etc.).
Al País Valencià, l’òrgan executiu és el Consell, i, existeix, de manera anàloga, el president del Consell (què és, també, el president del Generalitat, el és conjunt d’institucions d’autogovern). S’elegix de manera anàloga al President del Govern espanyol, però amb la diferència que ha d’ésser elegit entre els diputats de les Corts Valencianes. Aquest procedirà, igual que al govern espanyol, a nomenar el seu gabinet.
Al Bloc Nacionalista Valencià, el poder executiu rau en l’Executiva Nacional. Aquesta, de manera tradicional, és triada al Congrés Nacional des d’un sistema de llista tancada majoritari. Encara que tradicionalment sol haver-hi només…

Hui he vist la por als ulls

Estic trist ,molt trist.Vinc de la manifestació del 9 d'octubre i, puc dir que he vist moltes coses, però el que no he vist és democràcia.
He vist moltes banderes d'Espanya i blaveres dels increpadors, però no he vist democràcia. Les seues paraules eren "ven aquí fuera", "te voy a meter esa bandera por el coño", etc.He vist com manifestants fàcilment identificables entraven a provocar i la Policia Nacional no feia res per evitar-ho, però no he vist democràcia. He vist com un pare utilitzava al seu fill per provocar, i amb actitud agresiva (inclús anava a pegar-li manotada a un), però no he vist democràcia.He vist com es permetia una manifestació no autoritzada que podia alterar l'ordre públic. Segons la sacrosanta Constitució Espanyola, això és il·legal, però no he vist democràcia.He vist com la Policia Nacional tractava respectuosament, i inclús es coordinava amb els feixites. A nosaltres ens miraven amb cara de fàstic, però no he vist democràcia.He vi…