Soy un recién graduado en mi primer trabajo de desarrollo de software a tiempo completo. El trabajo prometía tutoría y desarrollo efectivo, pero en las 6 semanas que he estado aquí no me ha proporcionado nada de eso.
Los principales problemas con el medio ambiente:
El desarrollador principal (no mi jefe) suscribe abiertamente la idea de que la falta de documentación es una forma de seguridad laboral. Como resultado, nada está escrito. Ni siquiera hay una lista escrita de las bibliotecas utilizadas o los repositorios de git que tenemos, solo comentarios en el código o una descripción general de lo que hacen los fragmentos de código actuales. Además, tampoco quiere que la gente lo descubra por sí misma, por lo que simplemente les dice a los demás desarrolladores que dejen de trabajar si necesitan ayuda y él se encargará de esa sección. Si no puede completar un bloque de trabajo al 100% por su cuenta, se lo quitarán.
El gerente (mi jefe, que es técnico) parece estar desmotivado y desinteresado en el trabajo. Se toma todos los viernes libres y pasa el resto del tiempo en su oficina. Cuando le he preguntado si hay algo que deba hacer, promete volver a mí y no lo hace. Como resultado, con frecuencia no tengo nada que hacer excepto los cursos de Udemy.
Usamos Agile/Scrum, que aparentemente se trata de dar a los desarrolladores una sola oración para trabajar en sprints. Actualmente estoy asignado para trabajar en el seguimiento de inicio de sesión de usuario. La totalidad de lo que tengo que trabajar durante las dos semanas (cambiando algunas palabras por el anonimato) es "el sistema debe realizar un seguimiento de cuándo un usuario inicia sesión y cualquier información relevante sobre su inicio de sesión". ¿Qué significa "información relevante"? Nadie lo sabe. ¿Quién lo va a usar? No están seguros. Me dijeron que buscara cosas al azar para grabar y, aunque lo hice, es justo lo que querría. Los sprints también requieren que los desarrolladores calculen cuánto tiempo llevará una función, pero como no tenemos idea de lo que se solicitará antes de la reunión de sprint, damos estimaciones basadas en la adaptación de código que nunca hemos visto. Además,
¿Cuál es la mejor manera de extraer valor profesional de este lío?
Yo (y los otros 3 desarrolladores de mi proyecto) no tenemos tareas desafiantes, ya que el líder las toma para evitar la difusión del conocimiento.
Realmente no puedo colaborar con nadie. El jefe está ausente. El líder no quiere que nadie más haga preguntas o realmente descubra el código. Otros desarrolladores también buscan escapar y pasan su tiempo impulsando conceptos que les permitirán aprender nuevas tecnologías (proyectos a los que lamentablemente no estoy asignado).
Por ejemplo, la aplicación móvil tendrá su tercera reescritura completa en tres años. Solíamos hacer nativo, nos mudamos a Xamarin, y luego ahora el desarrollador de ese proyecto está lanzando Flutter.
No tengo una práctica seria para satisfacer las necesidades comerciales reales, ya que aparentemente en Agile la suma del análisis de requisitos para dos semanas de trabajo cabe en un post-it.
Aparte de cumplir básicamente con un estándar mediocre y transferir todo el tiempo a un proyecto mío independiente, no veo muchas oportunidades. ¿Cuál es la mejor manera de tener un valor de mercado sólido para saltar de 8 meses a un año a partir de ahora?
1
El desarrollador principal (no mi jefe) suscribe abiertamente la idea de que la falta de documentación es una forma de seguridad laboral. Como resultado, nada está escrito.
2
El gerente (mi jefe, que es técnico) parece estar desmotivado y desinteresado en el trabajo. Se toma todos los viernes libres y pasa el resto del tiempo en su oficina. Cuando le he preguntado si hay algo que deba hacer, promete volver a mí y no lo hace. Como resultado, con frecuencia no tengo nada que hacer excepto los cursos de Udemy.
Si tu puedes. Ver 1 )
Si nadie más va a documentar, entonces usted puede/debe.
3
Usamos Agile/Scrum, que aparentemente se trata de dar a los desarrolladores una sola oración para trabajar en sprints.
No, no lo es (excepto en su proyecto). Si estuviera desarrollando cascada (que parece haber sido renombrado como el método V recientemente), aún obtendría poca dirección.
Tienes una gran decisión que tomar . Sus opciones son las siempre populares "pulir su CV y empezar a buscar", o quedarse, ponerse manos a la obra e intentar cambiar las cosas.
Con solo 6 semanas, podría simplemente irse y ni siquiera mencionar el trabajo en su CV.
O bien , puede quedarse e intentar intentarlo. Si te quedas, probablemente no obtendrás mucha ayuda (del desarrollador principal o de su jefe); la gran pregunta es si encontrará obstáculos. Si espera que lo hará, se indica un cambio de carrera.
Podrías empezar a documentar las cosas. Ejecute el código a través de DoxyGen si es compatible con su idioma, o busque algo similar. Inicie una wiki. Cuando descubras lo que hace algún código, agrega comentarios. Agregue pruebas unitarias, si puede.
Acércate a tus compañeros de equipo. Parece que se han dado por vencidos. Pregúnteles si estarían dispuestos a contribuir a un wiki. Tal vez alguien ya lo intentó y encontró resistencia; lo sabrán y eso puede ayudarlo a tomar una decisión.
4
El desarrollador principal (no mi jefe) suscribe abiertamente la idea de que la falta de documentación es una forma de seguridad laboral
Lea sobre el factor autobús . ¿Quizás mencionárselo al jefe/PM? Si el desarrollador principal pasa por debajo de un autobús/se casa y se muda/se muda para cuidar a un pariente/etc., ¿qué sucederá? He visto esto, y no es bonito. De hecho, si es tan indispensable, ¿qué pasa cuando se va de vacaciones?
5
Además, el administrador de proyectos a menudo divide las tareas en elementos similares y las asigna fuera de la planificación del sprint, por lo que dos miembros del equipo pueden terminar fácilmente trabajando en lo mismo y duplicando el código.
No presagia nada bueno. Realmente suena como un libro de texto "cómo no ejecutar un proyecto" y es posible que le aconseje que mire a su alrededor. ¿Recibió otras ofertas? ¿Podrían esas empresas tener algo para ti?
No es así como quieres pasar los próximos 40 o 50 años. Si te esfuerzas por dos, ¿serás empleable en otro lugar después?
Tl;dr: cámbialo o vete. La actitud de tus compañeros debe ser un indicador. La actitud de tu jefe y PM ya es un indicador.
"we are agile, we write code not words."
- alguien no entiende Agile. Punto 2 " Working software over comprehensive documentation
" - si tuviera un dólar por cada idiota que me dijo que eso significa que no hay documentación ... Estás rodeado de idiotas, sal mientras la obtención sea buenaEmpieza a buscar trabajo ahora.
Estaba en una situación similar en mi primer trabajo de TI después de graduarme.
Cuando era evidente que no era un buen trabajo desde el principio, me convencí a mí mismo de 'al menos quedarme un año, porque no sería una buena idea irme temprano'.
El problema con ese tipo de pensamiento es que:
Busca un trabajo diferente. Hasta que encuentre uno con una oferta de trabajo legalmente vinculante, quédese donde está, porque pone dinero en su bolsillo.
Paralelamente, puedes intentar mejorar las cosas en tu lugar. Incluso si se trata de nada, es una buena experiencia de aprendizaje. Escriba lo que está sucediendo, por qué está mal y cuáles son los riesgos para la empresa.
El mayor riesgo es que con un líder de equipo como este, la empresa nunca logrará contratar a un desarrollador experimentado y mantenerlo. Para ti es el primer trabajo, y piensas mucho en irte. Imagina el futuro que harías tú con 5 años de experiencia en esa situación.
Si bien la gente habla del "factor de autobús" (lo que sucede es que el conductor es atropellado por un autobús, o por un colega que ha tenido suficiente, o en el lado positivo gana la lotería), en realidad no es un riesgo tan grande. Será costoso, pero la empresa puede contratar a alguien que sea realmente bueno en su trabajo, por un buen salario, y se arreglará.
El mayor costo proviene del hecho de que el líder maneja las cosas de manera totalmente ineficiente. Si un desarrollador junior tiene preguntas, no le quita el trabajo como líder y lo hace usted mismo (si el líder le dio el trabajo a un junior, entonces es un trabajo que el líder nunca debe tocar), lo ayuda a superar el problema, si es algo que necesita documentarse, dígales que lo documenten, y luego déjelos continuar.
Parece que tiene un PM (y todos saben que no está haciendo mucho), un líder (pero nadie sabe lo que está haciendo) y tres desarrolladores que no hacen ningún trabajo de desarrollo útil. Eso no es culpa tuya, obviamente, pero puedes intentar hacer todo lo posible para cambiarlo.
PD: Puedo ver que se abre un puesto de desarrollador principal una vez que su administración se despierte. Es cierto que tendrías que ser muy bueno para conseguir eso.
PD. Un reemplazo para el líder del equipo significaría que la empresa tendría repentinamente un líder de equipo efectivo y tres desarrolladores junior efectivos y motivados. Pueden lograr mucho.
¿Cuál es la mejor manera de tener un valor de mercado sólido para saltar de 8 meses a un año a partir de ahora?
Dada la información, su mejor resultado es una buena referencia y cualquier cosa con la que pueda educarse. Ambos son activos muy valiosos.
No espere demasiado cuando se una por primera vez a la fuerza laboral.
6 weeks
parte eclipsaría la good reference
parte. He recorrido un camino de algunos incluso antes de las 6 semanas (sin facturarlos; YkMMV), y no llegan al CV. A pesar de que este es el primer trabajo del OP, recomendaría olvidarlo si camina.Obtener experiencia profesional es más que solo mejorar sus habilidades técnicas con desafíos de programación del mundo real, sino también aprender a navegar en un lugar de trabajo disfuncional.
Ninguna empresa para la que trabajará hará las cosas de la manera correcta, y menos de la manera correcta para usted. Las nuevas empresas se mueven rápido y rompen cosas, las grandes empresas establecidas se ahogan en procesos y papeleo. No me malinterpreten, su situación actual suena bastante mal, pero sin verlo no sé cuánto es eso malo y cuánto el efecto "nuevo trabajo" donde todo es increíble o un basurero incendiado.
No hay bien o mal aquí. Puedes quedarte y aprender cómo sobrevivir a una empresa disfuncional, e incluso mejorarla (por ejemplo, documentándola, como decían algunas personas). Puedes irte para tratar de encontrar una mejor compañía, pero la hierba siempre será más verde en otro lugar. De cualquier manera, saldrás fortalecido y con mucha experiencia sobre cómo trabajar en una empresa del mundo real, incluso en las más disfuncionales.
Si quisiera irse con una nota amarga y al menos provocar un cambio al irse, podría entregar su aviso y hablar con la gerencia, explicándoles por qué las prácticas de desarrollo internas son directamente dañinas para el negocio. Sin embargo, desaconsejaría esto, aunque yo mismo lo hice en el pasado. Esto tiene dos razones:
Sé que esto es un poco insatisfactorio, pero solo vete. Sea profesional, llame a un profesional por el cual quiere irse y luego olvide que este proyecto existió alguna vez. En contraste con otra respuesta, no creo que sea su trabajo establecer la documentación si su líder trabaja activamente en contra de esto y a la gerencia no le importa. En última instancia, usted es un desarrollador, no un administrador de proyectos. Su trabajo es producir código. Si las decisiones de la gerencia y el jefe de desarrollo son desastrosas, puede señalarlo, pero si deciden no prestar atención a su advertencia, entonces aquí es donde debe trazar la línea. Especialmente si su cliente potencial no quiere que documente, no veo por qué es su trabajo hacerlo. No lo es.
EditarSolo una adenda: personalmente yo también seguiría trabajando ahí hasta que consiguieras un nuevo contrato. No haga de los problemas de esta empresa sus problemas.
Pida programar una reunión con su jefe sobre la retroalimentación. Pídele que escriba una hora específica antes de salir de la habitación y, si no lo hace, envíale un correo electrónico repetidamente hasta que programe una hora (aunque obviamente no envíes spam a su bandeja de entrada).
En esa reunión, dile exactamente lo que nos dijiste. Pregúntele si estaría dispuesto a hablar con el ingeniero senior, ya que cree que su comportamiento está dañando el negocio ya que aumenta el riesgo (busque el factor bus), al tiempo que impide que los otros programadores contribuyan de manera significativa. Le pagan un salario y tiene miedo de que sus acciones le impidan ganarlo adecuadamente, y eso significa que su trabajo está en riesgo la próxima vez que haya despidos.
Además, pregunte cómo hacer que sus tareas ágiles reciban los criterios de aceptación adecuados, para que sepa qué diablos se supone que debe hacer. Por el momento, solo tiene Agile implementado a medias.
Stephan Branczyk
Mawg dice que reincorpore a Monica
rugir
sombrazee
atascado en un contrato
atascado en un contrato
atascado en un contrato