Parasoft Blogは下記サイトに移転することになりましたのでお知らせいたします。
移転先:Parasoft DTP 特設サイト
新しいParasoft BlogのURLは次の通りです。
http://parasoft.techmatrix.jp/category/blog/
新しいParasoft Blogでは、これまで以上に価値のある情報をよりたくさん発信してまいります。新しいParasoft Blogをぜひご購読ください!
Parasoft Blog
このブログについて
ソフトウェア開発におけるエラーの予防やプロジェクト管理、品質管理を支援するParasoft製品のTIPSなどを、国内総販売代理店テクマトリックスのサポートスタッフが紹介しています。
2017年10月13日金曜日
2017年7月3日月曜日
【7/20(木)東京・7/27(木)大阪】RZ/A1開発効率化セミナー ARM DS-5 & C++test編
3月に開催しました
「RZ/A1とテストツールで実践する 品質向上スタートアップセミナー」へ
大勢の方にご参加いただき、誠にありがとうございました。
内容をリニューアルして、7月に東京・大阪でセミナーを開催いたします!
これまで1日かけて行っていたセミナーを
半日に凝縮することで、お手軽にノウハウを習得可能となっております。
まだ、席に余裕がございますが満席になりしだい随時終了となります。
無料セミナーとなりますので、お時間がございましたらぜひご参加ください。
RZ/A1開発効率化セミナー
ARM DS-5 & C++test編
画像・音声処理に最適なマイコン、
ルネサス社 「RZ/A1」シリーズ
RZ/A1の開発環境を簡単に構築できる統合開発環境、
DTSインサイト社 「DS-5」
DS-5上で下流工程に必要なテストを全て実現する
オールイン・ワン・テストツール、
テクマトリックス社 「C++test」
RZ/A1マイコンの概要やDS-5の演習、
C++testを使った効率的なテスト方法を
C++testを使った効率的なテスト方法を
たった半日で全て習得できます。
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
◆セミナー概要
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
【開催日程】
2017年7月20日(木)13:00~17:30 (豊洲会場@東京)
2017年7月27日(木)13:00~17:30 (新大阪会場@大阪)
【会場】
豊洲会場(豊洲フォレシア)
新大阪会場(CIVI新大阪東)
【費用】
【費用】
無料
【演習環境】
・統合開発環境「DS-5 Professional Edition」ARM社製
・デバッグアダプタ「ULINK2」 ARM社製
・RZ/A1 CPUボード アルファプロジェクト社製
・テストツール「C++test」Parasoft社製
【対象】
【対象】
RZ/A1ファミリを開発・評価を行なう方を対象としております。
【概要】
前半パートでは、RZ/A1の効果的なメモリの使用方法や、
開発ツールの使い方を基礎から解説します。
また、ARM(R) Development
Studio5(DS-5)と実機を使った演習を行ないます。
後半パートでは、弊社エンジニアがC/C++対応の静的解析・単体テストツール
「C++test」の紹介と、静的・動的解析機能を使った実践的な演習を行ないます。
より詳しい当日のカリキュラムは、
ルネサス エレクトロニクス株式会社様 のお申し込みページをご確認ください。
※ルネサス エレクトロニクス株式会社様 サイトに移動します。
2017年3月3日金曜日
【3/15(水)】RZ/A1とテストツールで実践する品質向上スタートアップセミナー
これまで東京限定だったノウハウセミナーを、
ご好評につき、中部地区でも開催決定!
まだ、席に余裕がありますが、満席になりしだい随時終了となります。
無料セミナーとなりますので、お時間がございましたらぜひご参加ください。
これまで東京限定だったノウハウセミナーを、
ご好評につき、中部地区でも開催決定!
まだ、席に余裕がありますが、満席になりしだい随時終了となります。
無料セミナーとなりますので、お時間がございましたらぜひご参加ください。
RZ/A1とテストツールで実践する
品質向上スタートアップセミナー
画像・音声処理に最適なマイコンのルネサス社提供の「RZ/A1」シリーズと、
RZ/A1の開発環境を簡単に構築できる「DS-5」
さらに、DS-5上で下流工程に必要なテストを全て実現する
オールイン・ワン・テストツール「C++test」
RZ/A1の開発環境を簡単に構築できる「DS-5」
さらに、DS-5上で下流工程に必要なテストを全て実現する
オールイン・ワン・テストツール「C++test」
RZ/A1ソフトウェアの開発導入から、最新技術で効率的なテストの仕方までを
たった1日で全て習得できます。
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
◆セミナー概要
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
【開催日程】
2017年3月15日(水)10:00~17:30
【会場】
名古屋会場(名古屋広小路プレイスビル)
【費用】
無料
【演習環境】
・統合開発環境「DS-5 Professional Edition」ARM社製
・デバッグアダプタ「ULINK2」 ARM社製
・RZ/A1 CPUボード アルファプロジェクト社製
・テストツール「C++test」Parasoft社製
【対象】
RZ/A1ファミリを開発・評価を行なう方を対象としております。
【概要】
前半パートでは、RZ/A1の効果的なメモリの使用方法や、
開発ツールの使い方を基礎から解説します。
また、ARM(R) Development Studio5(DS-5)と実機を使った演習を行ないます。
後半パートでは、弊社エンジニアがC/C++対応の静的解析・単体テストツール
「C++test」の紹介と、静的・動的解析機能を使った実践的な演習を行ないます。
より詳しい当日のカリキュラムは、
ルネサス エレクトロニクス株式会社様 のお申し込みページをご確認ください。
※ルネサス エレクトロニクス株式会社様 サイトに移動します。
「C++test」の紹介ページはこちらです→ C++test 製品紹介
2016年8月4日木曜日
dotTEST の フロー解析
先月リリースされた dotTEST DTP 10.2 では、フロー解析 がパワーアップし、『配列の範囲外アクセス』 やスレッド処理で発生しがちな、『デッドロック』や 『レースコンディション』の問題を検知できるようになりました。
今回は、新しいルールのご紹介の前に dotTEST のフロー解析をご紹介します。
フロー解析とは、プログラムを実行せずにソースコードを検証する静的解析です。
単体テストのようにテストデータを用意する必要なく、アプリケーションに潜むクリティカルな問題を発見することができます。
dotTEST には、フロー解析以外にも コーディングスタンダードがあります。これは、パターンマッチングでコードを検証するのに対してフロー解析は、クラスやメソッドをまたがった実行パスを解析し、特定の条件で発生するアプリケーションの問題を発見できます。
アプリケーションを動作させず問題を検出できるため、テスト環境での実行が難しい処理や想定していなかった例外パターンなどの問題を見つけることができます。
『NullReferenceException』の問題を例に、問題を見つけるまでの流れを説明します。
まず、変数からのメソッド呼び出しを 怪しいポイントとみなします。
そして、その怪しいポイントを通る実行パスを抽出し、メソッド呼び出しの変数に null が設定されている場合に、問題をレポートします。
では、実際のコードを例に説明いたします。
NullReferenceException が発生するコード:
このサンプルコードでは、BadGetEngineInfo メソッドは特定の条件を満たさない場合に、null を返してしまいます。
この状態で engine.ToString() が実行されると、NullReferenceException が発生します。
dotTESTのイメージ:
NullReferenceException が発生する原因は、今回の例だけでなく、
dotTEST DTP 10.2 では、NullReferenceExceptionの問題以外にも
などのクリティカルな問題を見つけることができます。
ぜひこの機会に、dotTEST のフロー解析をお試し頂き、品質の高いアプリケーションの開発に取り組んでください。
dotTESTの体験版はこちらから
次回は、新たに検出できるようになった『デッドロック』や『レースコンディション』の問題をご紹介します!
今回は、新しいルールのご紹介の前に dotTEST のフロー解析をご紹介します。
フロー解析とは、プログラムを実行せずにソースコードを検証する静的解析です。
単体テストのようにテストデータを用意する必要なく、アプリケーションに潜むクリティカルな問題を発見することができます。
dotTEST には、フロー解析以外にも コーディングスタンダードがあります。これは、パターンマッチングでコードを検証するのに対してフロー解析は、クラスやメソッドをまたがった実行パスを解析し、特定の条件で発生するアプリケーションの問題を発見できます。
アプリケーションを動作させず問題を検出できるため、テスト環境での実行が難しい処理や想定していなかった例外パターンなどの問題を見つけることができます。
『NullReferenceException』の問題を例に、問題を見つけるまでの流れを説明します。
まず、変数からのメソッド呼び出しを 怪しいポイントとみなします。
そして、その怪しいポイントを通る実行パスを抽出し、メソッド呼び出しの変数に null が設定されている場合に、問題をレポートします。
では、実際のコードを例に説明いたします。
NullReferenceException が発生するコード:
public EngineInfo BadGetEngineInfo()
{
EngineInfo engine = null;
// 条件により engine に値を設定
return engine;
}
public void NullReferenceFromMethodReturnValue()
{
var engine = BadGetEngineInfo();
string str = engine.ToString(); //怪しいポイント
Console.WriteLine(str);
}
このサンプルコードでは、BadGetEngineInfo メソッドは特定の条件を満たさない場合に、null を返してしまいます。
この状態で engine.ToString() が実行されると、NullReferenceException が発生します。
dotTESTのイメージ:
NullReferenceException が発生する原因は、今回の例だけでなく、
- 条件によってオブジェクトに値が入らない
- メソッドのパラメータが null
- コレクションや配列のオブジェクトが null
dotTEST DTP 10.2 では、NullReferenceExceptionの問題以外にも
- リソースリーク
- InvalidOperationException
- SQLインジェクション
- クロスサイトスクリプティング(XSS)
- 配列の境界外アクセス new
- デッドロック new
- レースコンディション new
などのクリティカルな問題を見つけることができます。
ぜひこの機会に、dotTEST のフロー解析をお試し頂き、品質の高いアプリケーションの開発に取り組んでください。
dotTESTの体験版はこちらから
次回は、新たに検出できるようになった『デッドロック』や『レースコンディション』の問題をご紹介します!
2016年7月21日木曜日
RedmineとParasoft DTPでプロジェクト進捗報告を効率化!
■プロジェクト管理とRedmine
あなたがソフトウェア開発に携わっているのならば、ほとんどの場合何かしらのプロジェクトに参加して作業を行っていると思います。そしてプロジェクトでは、タスク管理、進捗管理、障害(バグ)管理、品質管理など、様々な管理が行われていると思います。
これらの管理のため、近年RedmineというWebベースのプロジェクト管理ツールが人気を博しています。Redmineは、タスクや障害などをチケットとして管理できる他、構成管理リポジトリとの連携、作業時間の記録、ガントチャートの表示など、ソフトウェア開発のプロジェクト管理に必要な一通りの機能を有しています。
■プロジェクト進捗報告
ところで、プロジェクトの進行中、顧客や社内向けにプロジェクトの進捗報告を行います。進捗報告のためにデータを集めたり、体裁が決められた進捗報告書を作成することはなかなか大変な作業かと思います。Redmineは進捗報告に必要なデータを集めるための手助けになりますが、進捗報告書に記載するグラフを作成してくれるとは限りません。この場合、データをエクスポートして表計算ソフトで集計するなど、報告書の作成の度に手間がかかってしまいます。
ここで、Parasoft Development Testing Platform (Parasoft DTP) を使用すると、タスクや障害などの情報をグラフ化し、ソースコードの品質情報と共に表示することができます。
■進捗報告用のグラフの作成
Parasoft DTPはソフトウェアの開発とテストのためのプラットフォームです。Parasoft DTPの基本機能としては、Parasoft社の静的解析やコードメトリクス、テストの結果をグラフ化する機能があります。これに加えてサードパーティ製のツールやシステムからデータを取得し、任意のグラフを作成することができます。
Redmineのチケットの情報をグラフ化する場合は、まずRedmineのREST APIを利用してチケットの情報を収集します。次に収集した情報を集計するのですが、例えば週ごとにチケットのステータス別の件数を集計すると、タスクや障害のステータスの推移を示すことができ、タスクを消化できているかを確認できます。
また別の方法として、週ごとに新規で作成されたチケット数と完了したチケット数を集計すると、タスクや障害の発生数と消化数の推移を表示できます。単純に数を棒グラフにするだけでなく、その差異を折れ線グラフとして重ねて表示することで増減の推移を確認したり、期間内における差異の平均を求めることでプロジェクトが収束に向かっているかどうかを確認することもできます。
視点を変えてチケットを担当者別で集計すると、誰に作業が集中しているかを把握できます。チケットへの登録方法によって、障害発生の原因となったモジュール別に障害件数を表示するなど、報告に必要なグラフを必要なタイミングで自動的に作成し、進捗報告書に添付するグラフとして利用できます。
1つの画面の中に、静的解析や動的テストの結果に加えてチケットの情報も表示することで、プロジェクトの現状の品質と進捗が同時に把握できるようになり、プロジェクトの分析に役立ちます。さらに、ソースコードのメトリクスと工数の情報を掛け合わせると、生産性をも同時にレポートすることができます。
■まとめ
いかがでしたでしょうか。プロジェクト管理で人気のあるRedmineとParasoft DTPを組み合わせることで、顧客や社内で要求されるプロジェクト進捗報告書を作成が容易になることがお分かりいただけたと思います。
最後に、Parasoft DTPはこちらのサイトで詳しく紹介しております。また無償で2週間ご評価いただけますので、ぜひご利用ください。
ラベル:
Parasoft DTP,
Redmine,
プロジェクト管理,
自動化,
定量分析
2016年7月20日水曜日
dotTEST 新バージョンリリース!
ご紹介が遅くなってしまいましたが、 dotTEST の新しいバージョンがリリースされました。
今回は、リリースされたdotTESTについてご紹介いたします。
dotTESTとは、.NET Framework 対応のテストツールです。C#や Visual Basic.NET のコードに対してインスペクションやテストを自動化することができます。
dotTESTを用いたテストは、コマンドラインから実行したり、Visual Studio へプラグインしGUI から実行したり、開発環境に応じて使い方を選択することができます。
例えば、Jenkinsのような継続的インテグレーションツールと連携しテストを自動化することや、コーディングしながら自分の書いたコードに問題がないかをチェックすることもできます。
dotTESTには、次の機能があります。
コーディングスタンダード
社内のコーディング規約に準じているかをチェックしたり、バグを引き起こすコードになっていないか?また、可読性・保守性の高いコードになっているかをチェックすることができます。フロー解析
静的解析の一部で、アプリケーションを動かさず、アプリケーション動作時に発生するリソースリークや NullReferenceException といったクリティカルな問題を発見することができます。メトリクス解析
ソースコードの規模、複雑さ、保守性などのソースコードのメトリクスを解析することができます。
単体テストの実行
NUnit や MSTestで作成したテストケースを実行し、カバレッジを計測することができます。
アプリケーションカバレッジ
アプリケーションを実行しながら、カバレッジを計測することができます。次回から、dotTESTの機能と新しいバージョンでの変更点をご紹介していきます。 dotTEST の体験版をご用意しています。ご興味がある方は、こちらからダウンロードしてお試しください。
ラベル:
C#,
dotTEST,
Visual Basic.NET,
Visual Studio,
カバレッジ,
フロー解析,
メトリクス,
単体テスト
2016年6月20日月曜日
【7/15開催】 組込みソフトウェア品質向上セミナー
高度化した現代の組込みソフトウェアでは、たった一つの欠陥が大きな社会的影響を及ぼすことに繋がります。しかしながら、品質確保のために行うべき具体的な方策が見出だせていない方も多いのではないでしょうか?
かつて開発規模が短期間で急激に増加した開発現場で、「生産性倍増」を目標に掲げ、開発効率2倍/早期バグ検出率20%向上を実現した事例があります。
そこには、現代の開発現場の問題解決にも通じる数多くの“ヒント”が隠されていました。
今回はその実例の立役者である(株)オプテック 先端技術研究開発タスクフォースおよび、JASA IoT技術研究会 主査である 竹田 彰彦 様をお招きし、当時の事例をご紹介いただくとともに、組込みシステム開発の過去と今から分かる不変の開発・テストプロセス改革についてご講演いただきます。
さらにテクマトリックスからは、開発プロセスの中でもテストフェーズに着目し、うまくいかない 単体テスト と 静的解析 の実例をもとに、実際の開発現場で実践した効果を出すテスト運用法についてご紹介します。
品質の確保に課題を持たれている方必見の内容となっておりますので是非ご参加ください!
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
◆セミナー概要
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
【開催日程】
2016年7月15日(金)13:00~16:30 (開場:12:40)
【会場】
御茶ノ水ソラシティカンファレンスセンター 1F ROOM B
東京都千代田区神田駿河台4-6
【定員】
80名(定員になり次第締め切らせていただきます。)
※同一部署からのご参加は、2名様までとさせていただきます。
※ご同業の方の参加はご遠慮いただいております。
【参加費用】無料
【講演内容】
■「組込みシステム開発技法」~プロセス改革の軌跡~
【講師】
(株)オプテック先端技術研究開発タスクフォース エグゼクティブ・フェロー
JASA 状態遷移設計研究会、IoT技術研究会 主査
竹田 彰彦 様
【概要】
1.プロセス改革の軌跡
携帯電話開発で取り組んだ、プロセス改革を振り返り、特に、単体テストでの
ツール適用とその効果、導入に向けたポイントについて解説する。
2.組込みソフトウェアの開発手法
組込みソフトウェアの特性を理解し、特性に応じたプロセスや設計を
適用することの重要性。
3.品質向上に向けたテスト手法
ソフトウェアテスト概要、プロジェクト診断、ツール適用の必然性。
■開発現場で成果を出した単体テストの運用改善アプローチ
【講師】
テクマトリックス株式会社 ソフトウェアエンジニアリング技術部
渡辺 征一
【概要】
単体テストの実施において、ツールの運用がうまくいかない、効果がでないのはなぜなのか?
今回は過去のユースケースを元に、単体テストを成功につなげるためには、何が不足していて、何を実施する必要があったのかについてご紹介します。
■品質を底上げする静的解析運用のコツ ~バグの元を断ち切れ!~
【講師】
テクマトリックス株式会社 ソフトウェアエンジニアリング技術部
筒井 俊晴
【概要】
バグを早期発見するための取り組みをしていても、バグが減らない開発現場とバグが減っていく開発現場があります。
バグの元を断ち切るためには、どのような取り組みをすればよいのか?
本セッションでは、バグが減っていく開発現場の特徴とその理由を交えて、品質を底上げするための静的解析運用法をご紹介します。
※内容は、変更する場合がございます。あらかじめご了承ください。
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
◆予告情報! ※自分の席から気軽に参加!オンラインセミナー開始します!※
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
○「遠方まで出向いてセミナーに参加するのはなかなか難しい」
「まずは概要を知れるような機会がほしい」というお客様必見!
パソコンさえあれば、自分の席から製品紹介セミナーに参加できる、
オンラインセミナーを開始します!
※日程等は、近日弊社セミナーページでの公開を予定しています。
ラベル:
C++test,
Parasoft DTP,
セミナー,
ソフトウェア品質,
フロー解析,
自動化,
静的解析,
組み込み,
単体テスト,
定量分析、事例、活用術、育成、チーム
登録:
投稿 (Atom)