Git Product home page Git Product logo

mutants's Introduction

Mutants

Travis CI Build Status Coverage Status Codacy Badge


Hosteado en http://mutants-meli.appspot.com

Expone los servicios:


Enunciado

Magneto quiere reclutar la mayor cantidad de mutantes para poder luchar contra los X-Men.

Te ha contratado a ti para que desarrolles un proyecto que detecte si un humano es mutante basándose en su secuencia de ADN.

Para eso te ha pedido crear un programa con un método o función con la siguiente firma (En alguno de los siguiente lenguajes: Java / Golang / C-C++ / Javascript (node) / Python / Ruby):

boolean isMutant(String[] dna) // Ejemplo Java

En donde recibirás como parámetro un array de Strings que representan cada fila de una tabla de (NxN) con la secuencia del ADN. Las letras de los Strings solo pueden ser: (A,T,C,G), las cuales representa cada base nitrogenada del ADN.

Sabrás si un humano es mutante, si encuentras más de una secuencia de cuatro letras iguales​, de forma oblicua, horizontal o vertical.

Ejemplo (Caso mutante):

String[] dna = {"ATGCGA","CAGTGC","TTATGT","AGAAGG","CCCCTA","TCACTG"};

En este caso el llamado a la función isMutant(dna) devuelve “true”.

Desarrolla el algoritmo de la manera más eficiente posible.

Desafíos:

Nivel 1:

Programa (en cualquier lenguaje de programación) que cumpla con el método pedido por Magneto.

Nivel 2:

Crear una API REST, hostear esa API en un cloud computing libre (Google App Engine, Amazon AWS, etc), crear el servicio “/mutant/” en donde se pueda detectar si un humano es mutante enviando la secuencia de ADN mediante un HTTP POST con un Json el cual tenga el siguiente formato:

POST → /mutant/
{
    “dna”:["ATGCGA","CAGTGC","TTATGT","AGAAGG","CCCCTA","TCACTG"]
}

En caso de verificar un mutante, debería devolver un HTTP 200-OK, en caso contrario un 403-Forbidden

Nivel 3:

Anexar una base de datos, la cual guarde los ADN’s verificados con la API.

Solo 1 registro por ADN.

Exponer un servicio extra “/stats” que devuelva un Json con las estadísticas de las verificaciones de ADN: {“count_mutant_dna”:40, “count_human_dna”:100: “ratio”:0.4} Tener en cuenta que la API puede recibir fluctuaciones agresivas de tráfico (Entre 100 y 1 millón de peticiones por segundo). Entregar:

  • Instrucciones de funcionamiento (Libre, todas las que quiera)
  • Código Fuente (En el formato que quiera, lo más estándar posible).
  • Además del código fuente, cualquier pieza adicional que consideres aporta a la calidad del software construido.
  • URL de la API (Nivel 2 y 3)

Resultados

Nivel 1:

Se encuentra en el codigo fuente disponibilizado.

El lenguage utilizado es Java.

El algoritmo busca reducir las comparaciones necesarias, buscando inicialmente coincidencias de 2 en 2 a partir del segundo elemento de cada linea, siendo una linea una suceción de caracteres donde podría encontrarse la secuencia buscada, en cualquier dirección (vertical, horizontal, y diagonal en los dos sentidos).

Nivel 2:

Se encuentra en el codigo fuente y en el servicio web disponibilizados.

Se utiliza el servicio de Google App Engine.

El siguiente es un request de ejemplo del servicio requerido:

POST → http://mutants-meli.appspot.com/mutant { "dna":["ATGCGA","CAGTGC","TTATGT","AGAAGG","CCCCTA","TCACTG"] }

Nivel 3:

Se encuentra en el codigo fuente y en el servicio web disponibilizados.

Se anexa la base de datos en memoria H2.

El siguiente es un request de ejemplo del servicio requerido:

GET → http://mutants-meli.appspot.com/stats

Response: {“count_mutant_dna”:40, “count_human_dna”:100: “ratio”:0.4}

Notas y Extras:
  • Las pruebas unitarias se realizaron con JUnit 4.
  • Las pruebas integrales se realizaron con RestAssured.
  • Las pruebas de cobertura se realizan con Pitest (tests de mutación)
  • Se anexa Travis CI al proceso para automatizar builds (https://travis-ci.org/zogar1993/mutants)
  • Se anexa Coveralls al proceso para obtener información de covertura (https://coveralls.io/github/zogar1993/mutants?branch=master)
  • Se anexa Codacy al proceso para obtener información de calidad de codigo (https://app.codacy.com/project/zogar1993/mutants/dashboard)
  • Debido a que no encontré manera de levantar mas instancias en el servició de App Engine de Google sin que me lo debiten, el servicio expuesto no logra superar una prueba de carga exaustiva.
  • Debido a que no se generan mas de una instancia, no vi razón para cambiar H2 por una base con persistencia en disco, pero ese sería un cambio necesario si se levantasen varias instancias del servicio.
  • Se utilizó JMeter para efectuar las pruebas de carga.

mutants's People

Contributors

zogar1993 avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.