code-review-senior-perspective
8
总安装量
3
周安装量
#33679
全站排名
安装命令
npx skills add https://github.com/founderjourney/claude-skills --skill code-review-senior-perspective
Agent 安装分布
claude-code
3
opencode
2
replit
1
gemini-cli
1
Skill 文档
Code Review Senior Perspective
Framework para dar y recibir code reviews efectivos desde una perspectiva senior, enfocado en mentoring y calidad sostenible.
Filosofia de Code Review
OBJETIVOS (en orden de prioridad):
1. CORRECTNESS
- Hace lo que debe hacer?
- Maneja edge cases?
- Es seguro?
2. MAINTAINABILITY
- Otro developer puede entenderlo?
- Es facil de modificar?
- Sigue los patterns del proyecto?
3. PERFORMANCE
- Hay problemas obvios de performance?
- (No optimizar prematuramente)
4. STYLE
- Consistente con el codebase?
- (Menor prioridad - idealmente automatizado)
Framework de Review
Paso 1: Contexto Primero
ANTES DE LEER CODIGO:
1. Leer el PR description
- Que problema resuelve?
- Por que este approach?
2. Revisar el ticket/issue relacionado
- Cual es el acceptance criteria?
- Hay edge cases documentados?
3. Entender el scope
- Es un fix pequeño o feature grande?
- Cuantos archivos cambian?
REGLA: Si no entiendes el "por que", pregunta antes de
revisar el "como".
Paso 2: Review Estructurado
ORDEN DE REVISION:
1. TESTS
- Existen tests?
- Cubren el happy path?
- Cubren edge cases importantes?
- Son mantenibles?
2. API/INTERFACE
- El contrato publico tiene sentido?
- Es consistente con APIs existentes?
- Versionamiento considerado?
3. IMPLEMENTACION
- Logica correcta?
- Error handling apropiado?
- Efectos secundarios controlados?
4. INTEGRACION
- Como afecta al resto del sistema?
- Hay breaking changes?
- Migrations necesarias?
Paso 3: Categorizar Comentarios
ð´ BLOCKER (Request Changes)
- Bugs que romperian produccion
- Vulnerabilidades de seguridad
- Data loss potential
- Breaking changes no documentados
ð¡ SUGGESTION (Comentario)
- Mejoras de claridad
- Patterns mas idiomaticos
- Performance no-critica
- Refactoring opcional
ð¢ NIT (Opcional)
- Estilo/formato
- Naming alternativo
- Comentarios nice-to-have
⨠PRAISE (Positivo)
- Solucion elegante
- Buen handling de edge case
- Tests bien escritos
Comentarios Efectivos
Como NO Comentar
â "Esto esta mal"
(No explica que ni por que)
â "Usa filter en lugar de forEach"
(Dictatorial, sin contexto)
â "Por que no usaste X?"
(Puede sonar acusatorio)
â "Siempre deberias..."
(Absolutista, no considera contexto)
Como SI Comentar
â
Explicar el problema + sugerir solucion:
"Este endpoint puede tener N+1 queries cuando hay muchas
reservations. Considera usar eager loading:
`db('reservations').whereIn('property_id', propIds)`"
â
Preguntar antes de asumir:
"Veo que usas forEach aqui - hay alguna razon para no
usar filter/map? Si es intencional, un comentario
ayudaria a futuros lectores."
â
Ofrecer contexto:
"En este codebase usamos el pattern X para este tipo
de casos (ver example.js:45). No es blocker, pero
mantendria consistencia."
â
Reconocer tradeoffs:
"Esto funciona, pero podria tener issues de performance
con datasets grandes. Para el scope actual esta bien,
solo lo menciono para tenerlo en cuenta."
Patterns Problematicos (Red Flags)
En Node.js/JavaScript
// ð´ N+1 Query
const properties = await db('properties').select('*');
for (const prop of properties) {
prop.reservations = await db('reservations')
.where({ property_id: prop.id }); // N queries!
}
// â
Sugerencia:
const properties = await db('properties').select('*');
const propIds = properties.map(p => p.id);
const reservations = await db('reservations')
.whereIn('property_id', propIds);
// Agrupar en memoria por property_id
// ð´ Promise sin await/catch
function processPayment(data) {
stripe.paymentIntents.create(data); // Fire and forget!
}
// â
Sugerencia:
async function processPayment(data) {
try {
return await stripe.paymentIntents.create(data);
} catch (error) {
logger.error('Payment failed', { error, data });
throw error;
}
}
// ð´ SQL Injection
const users = await db.raw(
`SELECT * FROM users WHERE name = '${name}'` // Vulnerable!
);
// â
Sugerencia:
const users = await db('users').where({ name });
// o con raw: db.raw('SELECT * FROM users WHERE name = ?', [name])
En React
// ð´ useEffect sin deps o con deps incorrectas
useEffect(() => {
fetchData(userId);
}); // Corre en cada render!
// â
Sugerencia:
useEffect(() => {
fetchData(userId);
}, [userId]);
// ð´ Estado derivado innecesario
const [items, setItems] = useState([]);
const [filteredItems, setFilteredItems] = useState([]);
useEffect(() => {
setFilteredItems(items.filter(i => i.active));
}, [items]);
// â
Sugerencia:
const [items, setItems] = useState([]);
const filteredItems = useMemo(
() => items.filter(i => i.active),
[items]
);
// ð´ Props drilling excesivo
<Parent data={data}>
<Child data={data}>
<GrandChild data={data}>
<GreatGrandChild data={data} />
// â
Sugerencia: Context o composicion
En PostgreSQL/SQL
-- ð´ SELECT * en tabla grande
SELECT * FROM audit_logs WHERE user_id = 123;
-- â
Sugerencia:
SELECT id, action, created_at FROM audit_logs
WHERE user_id = 123
ORDER BY created_at DESC
LIMIT 100;
-- ð´ OFFSET para paginacion
SELECT * FROM orders
ORDER BY id
OFFSET 10000 LIMIT 20; -- Lento en offsets grandes
-- â
Sugerencia: Cursor-based pagination
SELECT * FROM orders
WHERE id > :last_seen_id
ORDER BY id
LIMIT 20;
-- ð´ OR en columnas diferentes (no usa indices bien)
SELECT * FROM reservations
WHERE property_id = 123 OR guest_id = 456;
-- â
Sugerencia: UNION si performance es critica
SELECT * FROM reservations WHERE property_id = 123
UNION
SELECT * FROM reservations WHERE guest_id = 456;
Seguridad: Checklist
EN CADA PR VERIFICAR:
AUTHENTICATION/AUTHORIZATION
[ ] Endpoints protegidos requieren auth
[ ] Permisos verificados (no solo auth)
[ ] Tenant isolation en multi-tenant
INPUT VALIDATION
[ ] Input sanitizado antes de usar
[ ] Queries parametrizadas (no concatenacion)
[ ] File uploads validados (tipo, tamaño)
DATA EXPOSURE
[ ] No logs de datos sensibles
[ ] Passwords hasheados (bcrypt, argon2)
[ ] Tokens/secrets en env vars, no en codigo
DEPENDENCIES
[ ] No dependencias con vulnerabilidades conocidas
[ ] Lockfile actualizado
Multi-tenancy: Review Especial
EN CODEBASES MULTI-TENANT:
ð´ CRITICO - Query sin tenant_id:
// PELIGRO: Puede filtrar datos de otros tenants
const reservations = await db('reservations')
.where({ status: 'confirmed' });
// â
SIEMPRE incluir tenant:
const reservations = await db('reservations')
.where({ tenant_id: req.tenant.id, status: 'confirmed' });
ð´ CRITICO - Tenant de request vs recurso:
// PELIGRO: Usuario puede acceder a recurso de otro tenant
app.get('/api/reservations/:id', async (req, res) => {
const reservation = await db('reservations')
.where({ id: req.params.id })
.first();
res.json(reservation); // Sin verificar tenant!
});
// â
SIEMPRE verificar ownership:
app.get('/api/reservations/:id', async (req, res) => {
const reservation = await db('reservations')
.where({
id: req.params.id,
tenant_id: req.tenant.id // Verificacion!
})
.first();
if (!reservation) {
return res.status(404).json({ error: 'Not found' });
}
res.json(reservation);
});
Dar Feedback como Senior
Enfoque MentorÃa
EN LUGAR DE:
"Esto esta mal, deberia ser X"
HACER:
"Este approach puede tener [problema] cuando [condicion].
Una alternativa que hemos usado es [solucion] porque [razon].
Que opinas?"
---
EN LUGAR DE:
Solo señalar problemas
HACER:
Reconocer lo bueno:
"Me gusta como manejaste [caso X]. El error handling en
[linea Y] es muy robusto."
---
EN LUGAR DE:
Reescribir el codigo del PR
HACER:
Guiar hacia la solucion:
"El patron que usamos para esto esta en [file:line].
Te puede servir como referencia."
Calibrar Feedback al Nivel
DEVELOPER JUNIOR:
- Mas explicaciones del "por que"
- Links a documentacion/ejemplos
- Ofrecer pair programming si es complejo
- Ser explicito sobre que es blocker vs nice-to-have
DEVELOPER SENIOR:
- Asumir que conocen los basics
- Enfocarse en edge cases y arquitectura
- Preguntar sobre decisiones de diseño
- Discutir tradeoffs como peers
DEVELOPER NUEVO EN EL PROYECTO:
- Señalar convenciones del proyecto
- Explicar contexto historico si es relevante
- Ser paciente con curva de aprendizaje
Recibir Reviews como Senior
MINDSET CORRECTO:
1. El reviewer esta mejorando el codigo, no atacandote
2. Cada comentario es oportunidad de aprender
3. Esta bien defender tu decision CON argumentos
4. "No lo se" es respuesta valida
COMO RESPONDER:
â
Si estas de acuerdo:
"Buen catch, fixed!"
â
Si quieres discutir:
"Entiendo la sugerencia. Opte por X porque [razon].
Pero estoy abierto a Z si crees que es mejor."
â
Si no entiendes:
"Puedes elaborar? No estoy seguro de entender
el problema que señalas."
â Evitar:
- Responder defensivamente
- Ignorar comentarios sin responder
- Cambiar sin entender por que
Checklist de Code Review
ANTES DE APROBAR:
FUNCIONALIDAD
[ ] El codigo hace lo que dice el PR
[ ] Edge cases manejados
[ ] Error handling apropiado
SEGURIDAD
[ ] Sin vulnerabilidades obvias
[ ] Tenant isolation (si aplica)
[ ] Input validation
CALIDAD
[ ] Tests cubren funcionalidad nueva
[ ] Codigo legible y mantenible
[ ] Consistente con patterns del proyecto
OPERACIONES
[ ] Migrations incluidas (si aplica)
[ ] Logs/monitoring apropiados
[ ] No breaking changes sin documentar
MI REVIEW
[ ] Comentarios claros y constructivos
[ ] Distingo blockers de suggestions
[ ] Reconozco lo positivo