public function testNuevaEjecucion()
 {
     // Crear un usuario e iniciar sesion
     $nick = "p" . time();
     $uarg = array("nombre" => "problem tester", "email" => $nick . "@example.net", "password" => "foobar23123", "nick" => $nick, "user" => $nick, "ubicacion" => "celaya");
     $result = c_usuario::nuevo($uarg);
     $result = c_sesion::login($uarg);
     // Crear un nuevo problema
     $contents = $titulo = "prob" . time();
     for ($i = 0; $i < 100; $i++) {
         $contents .= "lorem ipsum";
     }
     $arg = array("titulo" => $titulo, "problema" => $contents, "tiempoLimite" => 3456, "entrada" => "1 1\n1 2\n100 100\n", "salida" => "2\n3\n200\n");
     $result = c_problema::nuevo($arg);
     // Crear un nuevo envio
     $arg = array("id_problema" => $result["probID"], "lang" => "java", "plain_source" => "import java.io.*;\n\t\t\t\t\tclass Main{ public static void main(String []a) throws Exception{\n\t\t\t\t\tBufferedReader br = new BufferedReader(new FileReader(\"data.in\"));\n\t\t\t\t\tPrintWriter pw = new PrintWriter((\"data.out\"));\n\t\t\t\t\tString s;\n\t\t\t\t\twhile((s=br.readLine()) != null){\n\t\t\t\t\t\t\tpw.println(Integer.parseInt(s.split(\" \")[0])  + Integer.parseInt(s.split(\" \")[1])   );\n\t\t\t\t\t}\n\t\t\t\t\tpw.flush(); pw.close();\n\t\t\t\t\t} }");
     $result = c_ejecucion::nuevo($arg);
     //Revisar el estado del run hasta que no sea waiting...
     $detalles = c_ejecucion::details($result);
     $retry = 0;
     while ($retry < 5 && ($detalles["run"]["status"] == "WAITING" || $detalles["run"]["status"] == "JUDGING")) {
         $retry++;
         sleep(1);
         $detalles = c_ejecucion::details($result);
     }
     $this->assertEquals($detalles["run"]["status"], "OK");
 }
 public function testNuevoProblemaCorrecto()
 {
     $titulo = "a" . time();
     $rlistaprobs = array("public" => "NO");
     $res = c_problema::lista($rlistaprobs);
     $probs = $res["problemas"];
     $found = false;
     for ($i = 0; $i < sizeof($probs); $i++) {
         if ($probs[$i]["titulo"] == $titulo) {
             $found = true;
             break;
         }
     }
     $this->assertTrue(!$found);
     $contents = "";
     for ($i = 0; $i < 100; $i++) {
         $contents .= "a";
     }
     $arg = array("titulo" => $titulo, "problema" => $contents, "tiempoLimite" => 3456, "entrada" => "1 1\n1 2\n100 100\n", "salida" => "2\n3\n200\n");
     // crear un usuario e iniciar sesion
     $nick = "p" . time();
     $uarg = array("nombre" => "problem tester", "email" => $nick . "@example.net", "password" => "foobar23123", "nick" => $nick, "user" => $nick, "ubicacion" => "celaya");
     $result = c_usuario::nuevo($uarg);
     $result = c_sesion::login($uarg);
     $result = c_problema::nuevo($arg);
     $this->assertTrue(SUCCESS($result));
     $this->assertTrue(SUCCESS($result), "Crear un nuevo problema correctamente");
     $rlistaprobs = array("public" => "NO");
     $res = c_problema::lista($rlistaprobs);
     $probs = $res["problemas"];
     $found = false;
     $found_prob = null;
     for ($i = 0; $i < sizeof($probs); $i++) {
         if ($probs[$i]["titulo"] == $titulo) {
             $found = true;
             $found_prob = $probs[$i];
             break;
         }
     }
     $this->assertTrue($found);
     $this->assertEquals($found_prob["titulo"], $arg["titulo"]);
     $this->assertEquals($found_prob["problema"], $arg["problema"]);
     $this->assertEquals($found_prob["tiempoLimite"], $arg["tiempoLimite"]);
     $this->assertEquals($found_prob["usuario_redactor"], $argu["user"]);
 }
 /**
  * @param nombre
  * @param email
  * @param password
  * @param ubicacion
  * @param escuela
  * @param nick
  * @param twitter
  *
  * */
 public static function nuevo($request)
 {
     if (!array_key_exists("nombre", $request) || !array_key_exists("email", $request) || !array_key_exists("password", $request) || !array_key_exists("nick", $request)) {
         Logger::warn("Faltan parametros");
         return array("result" => "error", "reason" => "Faltan datos");
     }
     Logger::info("Creando usuario " . $request["nick"] . " / " . $request["email"]);
     if (!self::UsuarioValido($request)) {
         Logger::warn("Validacion fallo");
         return array("result" => "error", "reason" => "El nombre de usuario no debe contener espacios");
     }
     $result = self::getByNick($request);
     if (!is_null($result["user"])) {
         $msg = "Este usuario ya estan registrado";
         Logger::warn($msg);
         return array("result" => "error", "reason" => $msg);
     }
     $result = self::getByEmail($request);
     if (!is_null($result["user"])) {
         $msg = "Este email ya estan registrado";
         Logger::warn($msg);
         return array("result" => "error", "reason" => $msg);
     }
     $sql = "insert into Usuario (userID, nombre, pswd, ubicacion, escuela, mail, twitter) values (?,?,?,?,?,?,?)";
     $inputarray = array($request["nick"], $request["nombre"], crypt($request["password"]), isset($request["ubicacion"]) ? $request["ubicacion"] : "", isset($request["escuela"]) ? $request["escuela"] : "", $request["email"], "");
     global $db;
     $res = $db->Execute($sql, $inputarray);
     if ($res === false) {
         Logger::error("TEDDY:" . $db->ErrorNo() . " " . $db->ErrorMsg());
         return array("result" => "error", "reason" => "Error interno.");
     }
     $request["user"] = $request["nick"];
     $request["pass"] = $request["password"];
     $result = c_sesion::login($request);
     if (!SUCCESS($result)) {
         Logger::error("TEDDY: Error al iniciar sesion despues de registar usuario");
         return array("result" => "error", "reason" => "Error interno.");
     }
     Logger::info("Creado usuario " . $request["nick"]);
     return array("result" => "ok");
 }