news 2026/4/2 7:28:35

Team10: Code Standards — StudentSys / Campus Smart Service (Beta Phase)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Team10: Code Standards — StudentSys / Campus Smart Service (Beta Phase)

date: 2025.12.29
tags: [SoftwareEngineering, BetaSprint, CodeStandards, StudentSys]

Project entry:http://159.75.26.213
This post defines our team’s coding and collaboration standards for the Beta stage, so we can reduce integration bugs, avoid “works on my machine” failures, and make deployment reproducible.


1. Why We Need Code Standards (Lessons from Alpha)

During Alpha, many problems were not caused by “hard algorithms”, but by:

  • inconsistent endpoints and route prefixes

  • environment variables not synchronized or not loaded by the running process

  • ad-hoc server edits without PR review

  • unclear ownership (“everyone fixes everything”)

So in Beta we enforce standards to make our workrepeatable, reviewable, and deployable.


2. Repository Structure (Single Source of Truth)

We keep a clear top-level structure so every member knows where to work.

Recommended layout

StudentSys/ backend/ # Node.js/Express REST API frontend/ # Web UI python_services/ # FastAPI services (face/takeout/crowd/traffic) docs/ # API + deployment + conventions scripts/ # health checks, setup helpers infra/ # nginx/systemd/pm2 config templates README.md .env.example

Rules

  • No “random” files at root except repo-wide configs and README.

  • Anything deployment-related must be tracked indocs/+infra/.

  • A new module must include:

    • code folder

    • minimal README

    • known ports/endpoints documented indocs/


3. Branching Strategy (Simple & Enforceable)

We use a lightweight Git flow suitable for course projects.

  • main: alwaysdemo-ready(stable, runnable)

  • dev: integration branch for ongoing work (optional if team prefers main-only with PRs)

  • feature/<module>-<short-desc>: new features

  • fix/<bug>-<short-desc>: bugfixes

  • docs/<topic>: documentation-only changes

Rules

  • Never push directly tomain.

  • All merges tomainmust go through PR + review.

  • Hotfix allowed only when demo is blocked, but still via PR.


4. Issue Workflow (Everything Non-trivial Has an Issue)

For Beta sprint blogs, dev progress must be backed by Issues/PRs. We standardize that here.

Issue must include

  • Title:[Module] short description

  • Background / expected behavior

  • Acceptance criteria (how we know it’s done)

  • Labels:frontend,backend,ai-service,docs,bug,enhancement,deployment

  • Assignee + estimated effort (small/medium/large)

Definition of Done

  • Code merged via PR

  • Basic local test passed

  • Endpoint/docs updated if interface changed

  • Screenshot/log evidence if required by sprint blog


5. Pull Request (PR) Rules

PRs are not optional—they are our safety net.

PR title format

  • feat(frontend): ...

  • fix(backend): ...

  • docs: ...

  • chore(deploy): ...

PR description must include

  • What changed and why

  • Linked Issues:Closes #123

  • Test evidence: how you verified (commands + screenshots where needed)

  • Deployment impact: does this require env/nginx/systemd updates?

Minimal review checklist

  • Code compiles/runs

  • No secrets committed

  • Routes/endpoints match docs

  • Error handling is user-friendly (not raw stack traces)

  • Logging added for key operations

  • No breaking changes without notice

Optional evidence placeholder for blog:
[IMG_PLACEHOLDER: PR_review_screenshot.png]


6. Commit Message Convention

We use conventional commits to keep history readable and searchable.

Format

  • feat: add takeout detection UI

  • fix: correct DB env loading

  • refactor: simplify router structure

  • docs: update deployment checklist

  • chore: update dependencies

Rules

  • One commit = one logical change (avoid mixing unrelated changes)

  • Commit early and often, but don’t commit broken builds to shared branches


7. Backend Standards (Node.js / Express)

7.1 API Design

  • All backend routes must be under a consistent prefix, e.g./api/...

  • Add health check endpoint (backend):/api/health

  • Use consistent JSON response format:

Success

{ "code": 0, "message": "ok", "data": { ... } }

Error

{ "code": 1001, "message": "Invalid input", "hint": "Check email format", "data": null }

7.2 Error Handling

  • Never return raw stack traces to frontend

  • Log the internal error; return a user-friendly message

7.3 Configuration

  • All sensitive config must come from environment variables

  • Backend must fail fast with clear log output if env is missing


8. Database Standards (MySQL/MariaDB)

  • Useleast privilegeDB user for runtime (notroot)

  • DB migrations/initialization must be documented:

    • schema changes

    • required tables

    • seed data (if any)

  • Changes that break schema require:

    • a short migration note indocs/DEPLOYMENT.md

    • coordination with backend owners


9. Python AI Services Standards (FastAPI/Uvicorn)

We have multiple services (face/takeout/crowd/traffic). Consistency matters.

9.1 Health Endpoints

Every service must expose:

  • /health(returns 200 + simple JSON)

When proxied by Nginx, external access should be consistent:

  • /api/face/health

  • /api/takeout/health

  • /api/crowd/health

  • /api/traffic/health

9.2 Dependency Rules

  • requirements.txtmust beplatform-neutral(no Windows wheels)

  • System dependencies (e.g., OpenCV runtime libs) must be listed indocs/DEPLOYMENT.md

9.3 Runtime Rules

  • CPU-first by default (GPU only if infrastructure confirmed)

  • Add warm-up strategy if cold start is slow

  • Log request info and inference timing (p50/p95 later if possible)


10. Frontend Standards

10.1 UI Consistency

  • Use consistent navigation labels and page layout spacing

  • Forms must validate input and show actionable errors

10.2 API Integration

  • Centralize API base URL and request wrapper

  • Handle common error codes:

    • 401/403: show login prompt

    • 404: show “feature not available / wrong route”

    • 500: show “system busy, try again” with retry suggestion


11. Documentation Rules

Docs are part of the deliverable, not optional.

Must-have docs

  • docs/DEPLOYMENT.md

    • ports

    • env variables

    • system packages

    • restart commands (pm2/systemd)

    • nginx routing notes

  • docs/API.md

    • routes + request/response examples

    • error codes

Rule

  • If you change an endpoint, you must updatedocs/API.mdin the same PR.


12. Testing & Quality Baseline (Minimum Standard)

We keep it minimal but effective.

Required

  • A simple “health check script” (bash) that curls all services

  • Smoke test steps recorded in sprint blog (screenshots or terminal output)

Recommended

  • ESLint/Prettier for frontend/backend formatting

  • Python formatting tool (e.g., black) if feasible


13. Deployment Discipline (No More “Edit on Server”)

Rule

  • No direct editing on production server without PR

  • Deployment changes must be recorded:

    • updateinfra/configs

    • document indocs/DEPLOYMENT.md

Standard deployment checklist

  • env check → DB check → service status check → health check → public access check


14. Ownership & Communication

To avoid duplicated work and missing tasks, we define module owners:

  • Backend owner: API + DB integration

  • Frontend owner: UI + integration

  • Deployment owner: Nginx + pm2/systemd + env

  • AI services owner: FastAPI services

If a change impacts another module, it must be communicated in Issue/PR description.


15. Conclusion

These standards are designed to reduce integration failures, increase collaboration efficiency, and make our Beta sprint outputsreviewable and demo-ready. In the next sprint blogs, we will enforce evidence-based reporting (Issues/PRs/results) and keep documentation synchronized with code changes.

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/29 5:51:29

pykt-toolkit知识追踪完整指南:从入门到实战应用

pykt-toolkit知识追踪完整指南&#xff1a;从入门到实战应用 【免费下载链接】pykt-toolkit 项目地址: https://gitcode.com/gh_mirrors/py/pykt-toolkit 知识追踪作为教育技术领域的核心研究方向&#xff0c;通过分析学生的学习行为数据来预测知识掌握程度。pykt-tool…

作者头像 李华
网站建设 2026/4/2 0:36:14

Camoufox反检测浏览器:突破网站防护的终极解决方案

Camoufox反检测浏览器&#xff1a;突破网站防护的终极解决方案 【免费下载链接】camoufox &#x1f98a; Anti-detect browser 项目地址: https://gitcode.com/gh_mirrors/ca/camoufox 在数据采集和网络自动化领域&#xff0c;网站的反爬虫技术日益精密&#xff0c;传统…

作者头像 李华
网站建设 2026/4/2 9:26:42

GaLore秩分解技术:在极低显存下完成全参数更新

GaLore秩分解技术&#xff1a;在极低显存下完成全参数更新在大模型时代&#xff0c;一个看似简单的问题正变得越来越尖锐&#xff1a;我们真的需要为每一个梯度分配完整的浮点存储空间吗&#xff1f; 当LLM的参数量突破百亿、千亿&#xff0c;训练一次动辄消耗数百GB显存时&…

作者头像 李华
网站建设 2026/3/31 18:42:31

开源区块链项目Corda贡献指南:从入门到精通的全方位路径

开源区块链项目Corda贡献指南&#xff1a;从入门到精通的全方位路径 【免费下载链接】corda Corda is an open source blockchain project, designed for business from the start. Only Corda allows you to build interoperable blockchain networks that transact in strict…

作者头像 李华
网站建设 2026/3/30 8:58:52

Ristretto缓存引擎:TinyLFU算法的性能优化实战

Ristretto缓存引擎&#xff1a;TinyLFU算法的性能优化实战 【免费下载链接】ristretto A high performance memory-bound Go cache 项目地址: https://gitcode.com/gh_mirrors/ri/ristretto 在高性能内存缓存系统中&#xff0c;Ristretto通过其独特的TinyLFU准入策略实现…

作者头像 李华
网站建设 2026/4/1 19:29:48

Vita3K模拟器完整指南:从零开始畅玩PlayStation Vita经典游戏

Vita3K模拟器完整指南&#xff1a;从零开始畅玩PlayStation Vita经典游戏 【免费下载链接】Vita3K Experimental PlayStation Vita emulator 项目地址: https://gitcode.com/gh_mirrors/vi/Vita3K 还在怀念那些只能在PlayStation Vita上体验的经典游戏吗&#xff1f;Vit…

作者头像 李华