mirror of
https://github.com/kou029w/intro-to-software-testing.git
synced 2025-01-18 16:08:00 +00:00
194 lines
5 KiB
Markdown
194 lines
5 KiB
Markdown
---
|
|
title: ソフトウェアテスト概論
|
|
marp: true
|
|
paginate: true
|
|
---
|
|
|
|
# ソフトウェアテスト概論
|
|
|
|
WebDINO Japan エンジニア
|
|
[渡邉浩平](https://github.com/kou029w)
|
|
![w:200](https://github.com/kou029w.png)
|
|
|
|
---
|
|
|
|
## なぜテストをするのか
|
|
|
|
---
|
|
|
|
## 品質
|
|
|
|
品質とは製品としての価値
|
|
|
|
開発したサービスや製品によって利用者への価値の提供を目指している
|
|
製品としての価値を支えているのは品質
|
|
|
|
---
|
|
|
|
## <ruby>狩野<rp> (</rp><rt>かのう</rt><rp>)</rp></ruby>モデル
|
|
|
|
![bg right:60% fit](https://i.gyazo.com/6f612bf15c62fd9b8465bcbe21d4d397.png)
|
|
|
|
顧客の求める品質のモデル
|
|
|
|
<!-- _footer: 図の出典: 狩野紀昭 (1984)「魅力的品質と当たり前品質」をもとに改変して作成 -->
|
|
|
|
---
|
|
|
|
## 魅力的品質と当たり前品質
|
|
|
|
魅力的品質についてはみなさんが考えてほしい
|
|
|
|
ソフトウェア開発における当たり前品質に関するヒントをご紹介します
|
|
|
|
---
|
|
|
|
## CI/CD (Continuous Integration and Continuous Delivery)
|
|
|
|
変更すると決めてからユーザーが使えるようになるまでの一連の継続的な活動
|
|
|
|
「サイクルタイムを短く、品質を高く」
|
|
|
|
> ![デプロイメントパイプライン](https://i.gyazo.com/96475ee59df81cb75a2e5ca53cba5758.png)
|
|
|
|
<!-- _footer: 図の出典: David Farley, Jez Humble, 和智 右桂, 高木 正弘 (2017)「継続的デリバリー」 -->
|
|
|
|
品質: 最適なレベルに保つ
|
|
手段: 自動化し機械によって繰り返す、頻繁なフィードバックを得る
|
|
|
|
---
|
|
|
|
## 自動化とフィードバック
|
|
|
|
どちらも欠かせない
|
|
|
|
なぜなら…
|
|
|
|
- 自動化していなければ素早く変更を反映させられない
|
|
- フィードバックが得られなければ最適な品質を見極められない
|
|
|
|
---
|
|
|
|
## テスト
|
|
|
|
品質の評価
|
|
|
|
> ソフトウェアが正しく動作しないと、経済的な損失、時間の浪費、信用の失墜など、さまざまな問題が発生し、時には傷害や死亡事故になることもある。ソフトウェアテストはソフトウェアの品質を評価し、運用環境でソフトウェアの故障が発生するリスクを低減する 1 つの手段である。
|
|
|
|
<!-- _footer: 引用元: JSTQB (2021) http://jstqb.jp/dl/JSTQB-SyllabusFoundation_Version2018V31.J03.pdf 「1.1 テストとは何か?」より -->
|
|
|
|
---
|
|
|
|
## まとめ
|
|
|
|
- 品質とは製品としての価値
|
|
- 品質を高めるヒント … CI/CD、テスト
|
|
|
|
---
|
|
|
|
## 便利な CI/CD サービスとテストツール
|
|
|
|
JavaScript と TypeScript での開発を支える便利なサービスやツールの紹介
|
|
|
|
---
|
|
|
|
## CI/CD サービス
|
|
|
|
CI/CD を実現するための環境
|
|
|
|
- [CircleCI](https://circleci.com/ja/)
|
|
- [GitHub Actions](https://github.co.jp/features/actions)
|
|
- [GitLab CI/CD](https://docs.gitlab.com/ee/ci/)
|
|
|
|
---
|
|
|
|
## GitHub Actions による自動テストの例
|
|
|
|
`.github/workflows/test.yml`
|
|
|
|
```yml
|
|
name: test
|
|
on: push
|
|
jobs:
|
|
main:
|
|
runs-on: ubuntu-latest
|
|
steps:
|
|
- uses: actions/checkout@v2
|
|
- uses: actions/setup-node@v2
|
|
with: { node-version: lts/*, cache: npm }
|
|
- run: npm ci
|
|
- run: npm test
|
|
```
|
|
|
|
`git push`するたびに繰り返し GitHub が実行環境を構築し自動的にテストを実行
|
|
|
|
---
|
|
|
|
## テストフレームワーク
|
|
|
|
テストをサポートするための一連のツール
|
|
|
|
- [Jest](https://jestjs.io/ja/)
|
|
- [Mocha](https://mochajs.org/)
|
|
- [Tape](https://github.com/substack/tape)
|
|
|
|
---
|
|
|
|
## E2E テストツール
|
|
|
|
Web ブラウザーの操縦を自動化するためのツール
|
|
|
|
- [Playwright](https://playwright.dev/)
|
|
- [Puppeteer](https://pptr.dev/)
|
|
- [Selenium](https://www.selenium.dev/selenium/docs/api/javascript/index.html)
|
|
|
|
---
|
|
|
|
## 他
|
|
|
|
- 型システム … [TypeScript](https://www.typescriptlang.org/)
|
|
- 静的解析ツール … [ESLint](https://eslint.org/)
|
|
- UI を確認するためのショーケースツール … [Storybook](https://storybook.js.org/)
|
|
- 依存関係の自動更新 … [Renovate](https://www.whitesourcesoftware.com/free-developer-tools/renovate/)
|
|
- セキュリティ監査 … [LGTM](https://lgtm.com/)、[Snyk](https://snyk.io/)
|
|
- コンプライアンス監査 … [FOSSA](https://fossa.com/)
|
|
|
|
---
|
|
|
|
## まとめ
|
|
|
|
JavaScript と TypeScript での開発を支える便利なサービスやツールを紹介
|
|
|
|
---
|
|
|
|
## 後付
|
|
|
|
---
|
|
|
|
## 話していないこと
|
|
|
|
- ソフトウェア設計技法
|
|
- テスト設計技法
|
|
- リファクタリング
|
|
|
|
---
|
|
|
|
## テストピラミッド
|
|
|
|
テスト戦略の 1 つ
|
|
|
|
コストに応じた適切な粒度で行う
|
|
|
|
Mike Cohn によって提唱
|
|
|
|
![bg right fit](https://i.gyazo.com/dd948eed8f6c94e7821c92b65e38c960.png)
|
|
|
|
<!-- _footer: 参考文献: Mike Cohn (2009) "Succeeding With Agile" -->
|
|
|
|
---
|
|
|
|
## ![h:0.8em][github.svg] フィードバック
|
|
|
|
[このスライドを編集する](https://github.com/kou029w/intro-to-software-testing/edit/main/README.md) / [問題を報告する](https://github.com/kou029w/intro-to-software-testing/issues/new)
|
|
|
|
[github.svg]: https://cdnjs.cloudflare.com/ajax/libs/simple-icons/5.7.0/github.svg
|