0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

[2/5] GiteaでCI/CDパイプラインを構築する アプリケーション構築編

0
Last updated at Posted at 2026-05-06

はじめに

この記事はGiteaを使ったCI/CDパイプラインの構築方法を展開する連載の一つである。

連載の各記事へは以下からジャンプできる。

  1. Giteaインストール編
  2. アプリケーション構築編
  3. テスト編
  4. ビルド編
  5. デプロイ編

サンプルアプリケーションとテストコードを用意する

この記事では以下の赤枠部であるサンプルアプリケーションとテストコードのプッシュをやってみよう。

サンプルアプリケーションとして、Honoでバックエンドアプリケーションを作成してみる。

Giteaの画面右上からNew Repositoryを選択する。

Repository Nameにリポジトリ名を設定する。(今回はcicd-exampleとしている。)

開発環境上でプロジェクトを作成する。

$ npm create hono@latest cicd-example

> npx
> "create-hono" cicd-example

create-hono version 0.19.4
✔ Using target directory … cicd-example
✔ Which template do you want to use? nodejs
✔ Do you want to install project dependencies? Yes
✔ Which package manager do you want to use? npm
✔ Cloning the template
✔ Installing project dependencies
🎉 Copied project files
Get started with: cd cicd-example

作成したプロジェクトをGiteaへプッシュする。

# 作成したプロジェクトのディレクトリに移動する
$ cd cicd-example/

# gitを初期化する
$ git init

# リモートリポジトリとしてGiteaで作成したリポジトリを設定する
$ git remote add origin http://${Giteaホスト}/kkawaharanet/cicd-example.git

# 現時点のファイル全てをステージに追加する
$ git add -A

# コミットする
$ git commit -m "initial commit"

# プッシュする
$ git push --set-upstream origin main

以下のようにファイルの一覧を見ることができればプッシュに成功している。

サンプルアプリケーションを実装する

サンプルアプリケーションは1+1の結果をユーザーへ返すことにする。

本当はもっと面白いアプリケーションを作っても良いが、今回はCI/CDパイプライン構築の実践が目的なので超単純化している。

CI/CDパイプラインによる自動テストを実現したいので、テストのしやすい設計を行う。

1+1の結果をユーザーに返すという処理の責務を以下のように分けることにする。

  • 足し算をする
  • 計算結果をユーザーに返す

足し算をする

src/sum.tsに足し算の処理を実装する。

src/sum.ts
/**
 * 足し算をする
 * @param a オペランド
 * @param b オペランド
 * @returns 足し算の結果
 */
export function sum(a: number, b: number): number {
  return a + b;
}

計算結果をユーザーに返す

src/app.tsに足し算APIを実装する。

src/app.ts
import { Hono } from "hono";
import { sum } from "./sum.js";

export const app = new Hono();

/**
 * 足し算API
 */
app.get("/sum", (c) => {
  return c.json({ result: sum(1, 1) });
});

src/index.tsで外部にAPIを公開する。

src/index.ts
import { serve } from "@hono/node-server";
import { app } from "./app.js";

serve(
  {
    fetch: app.fetch,
    port: 3000,
  },
  (info) => {
    console.log(`Server is running on http://localhost:${info.port}`);
  },
);

ビルドチェックを行う

TypeScriptでの開発なので、ビルドエラーを確認できるようにしておく。package.jsonに以下をマージする。

package.json
 {
   "name": "cicd-example",
   "type": "module",
   "scripts": {
     "dev": "tsx watch src/index.ts",
     "build": "tsc",
     "start": "node dist/index.js",
+    "typecheck": "tsc --noemit"
   },
   "dependencies": {
     "@hono/node-server": "^1.19.14",
     "hono": "^4.12.17"
   },
   "devDependencies": {
     "@types/node": "^20.11.17",
     "tsx": "^4.7.1",
     "typescript": "^5.8.3"
   }
 }

npm run typecheckを実行し、以下のように何もエラーメッセージが出力されなければビルドは問題ない。

$ npm run typecheck

> typecheck
> tsc --noemit

$

動作確認する

npm run devでサーバーを起動する。

$ npm run dev

> dev
> tsx watch src/index.ts

Server is running on http://localhost:3000

Webブラウザでhttp://localhost:3000/sumにアクセスすると、以下のように1+1の結果が返ってくるはずだ。

{ "result": 2 }

ここまでのディレクトリ構成は以下のようになっている。

.
├── README.md
├── package-lock.json
├── package.json
├── src
│   ├── app.ts
│   ├── index.ts
│   └── sum.ts
└── tsconfig.json

テストコードを作成する

テストフレームワークにはVitestを使う。Vitestをインストールする。

$ npm i -D vitest

vitest.config.tsを作成する。

vitest.config.ts
/// <reference types="vitest" />
import { defineConfig } from "vitest/config";

export default defineConfig({
  test: {
    exclude: ["dist/**", "node_modules/**"],
  },
});

package.jsonに以下をマージし、アプリケーションにバージョンを設定する。またスクリプトからテストを実行できるようにする。

package.json
 {
   "name": "cicd-example",
   "type": "module",
+  "version": "1.0.0",
   "scripts": {
     "dev": "tsx watch src/index.ts",
     "build": "tsc",
     "start": "node dist/index.js",
     "typecheck": "tsc --noemit",
+    "test": "vitest"
   },
   "dependencies": {
     "@hono/node-server": "^1.19.14",
     "hono": "^4.12.17"
   },
   "devDependencies": {
     "@types/node": "^20.11.17",
     "tsx": "^4.7.1",
     "typescript": "^5.8.3",
     "vitest": "^4.1.5"
   }
 }

テストコードを作成していく。

足し算をする処理のテストコードを作成する

src/sum.test.tssrc/sum.tsのテストコードを作成する。

src/sum.test.ts
import { describe, expect, test } from "vitest";
import { sum } from "./sum.js";

describe("sum", () => {
  test("足し算ができること", () => {
    expect(sum(1, 1)).toBe(2);
  });
});

計算結果をユーザーに返すテストコードを作成する

src/app.test.tssrc/app.tsのテストコードを作成する。

src/app.test.ts
import { describe, expect, test } from "vitest";
import { app } from "./app.js";

describe("足し算API", () => {
  test("正しい足し算の結果を得られること", async () => {
    const response = await app.request("/sum");

    // HTTPステータスコードが200であること
    expect(response.status).toBe(200);

    // 足し算の結果が期待値と一致すること
    const body = await response.json();
    expect(body).toEqual({ result: 2 });
  });
});

ここまでのディレクトリ構成は以下となる。

.
├── README.md
├── package-lock.json
├── package.json
├── src
│   ├── app.test.ts
│   ├── app.ts
│   ├── index.ts
│   ├── sum.test.ts
│   └── sum.ts
├── tsconfig.json
└── vitest.config.ts

テストを実行する

npm run testを実行し、テストが成功することを確認する。

$ npm run test

> test
> vitest


 DEV  v4.1.2 /path/to/cicd-example

 ✓ src/sum.test.ts (1 test) 2ms
 ✓ src/app.test.ts (1 test) 15ms

 Test Files  2 passed (2)
      Tests  2 passed (2)
   Start at  14:02:42
   Duration  129ms (transform 33ms, setup 0ms, import 58ms, tests 17ms, environment 0ms)

 PASS  Waiting for file changes...
       press h to show help, press q to quit

tsconfig.jsonを設定する

今後アプリケーションをビルドするときのためにtsconfig.jsonを設定しておく。

tsconfig.json
 {
   "compilerOptions": {
     "target": "ESNext",
     "module": "NodeNext",
     "strict": true,
     "verbatimModuleSyntax": true,
     "skipLibCheck": true,
     "types": ["node"],
     "jsx": "react-jsx",
     "jsxImportSource": "hono/jsx",
     "outDir": "./dist",
+    "rootDir": "./src"
   },
+  "exclude": ["node_modules", "vitest.config.ts"]
 }

Giteaへプッシュする

テストが通ったらコミットし、Giteaへプッシュしておこう。

$ git add -A
$ git commit -m "1+1の結果をユーザーに返す処理を作成した"
$ git push

振り返り

今回は結構いろいろなことを行った。

  • サンプルアプリケーションを実装することができた
  • サンプルアプリケーションのテストを実装することができた
  • サンプルアプリケーションをGiteaへプッシュすることができた

次回

次回はいよいよGitea Actionsを使ってCI/CDパイプラインを構築する。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?