Visual Studio での SharePoint ツールの拡張機能のデバッグ

Visual Studio の実験用インスタンスまたは通常のインスタンスで、SharePoint ツールの拡張機能をデバッグできます。拡張機能の動作をトラブルシューティングする必要がある場合は、レジストリ値を変更して、追加のエラー情報を表示し、Visual Studio での SharePoint コマンドの実行方法を構成することもできます。

Visual Studio の実験用インスタンスで拡張機能をデバッグする

テストされていない拡張機能による不慮の破損から Visual Studio 開発環境を保護するために、Visual Studio SDK には、拡張機能のインストールおよびテストに使用できる代替の Visual Studio インスタンス (実験用インスタンスと呼ばれます) が用意されています。新しい拡張機能は Visual Studio の通常のインスタンスを使用して開発しますが、デバッグと実行は実験用インスタンスで行います。詳細については、「Visual Studio の実験用インスタンス」を参照してください。

VSIX プロジェクトを使用して拡張機能を配置し、その VSIX プロジェクトをソリューションのスタートアップ プロジェクトにする場合は、ソリューションをデバッグするときに、実験用インスタンスで拡張機能が自動的にインストールされて実行されます。スタートアップ プロジェクトとは、複数のプロジェクトを含むソリューションをデバッグするときに開始されるプロジェクトです。VSIX プロジェクトを使用して拡張機能を配置する方法の詳細については、「Visual Studio での SharePoint ツールの拡張機能の配置」を参照してください。スタートアップ プロジェクトの詳細については、「[NIB] 12/13 方法: スタートアップ プロジェクトを選択する」を参照してください。

Visual Studio の実験用インスタンスでさまざまな種類の拡張機能をデバッグする方法を示す例については、次のチュートリアルを参照してください。

Visual Studio の通常のインスタンスで拡張機能をデバッグする

Visual Studio の通常のインスタンスで拡張機能プロジェクトをデバッグするには、まず、その拡張機能を通常のインスタンスにインストールします。次に、デバッガーを Visual Studio の第 2 プロセスにアタッチします。デバッグの完了後、拡張機能を削除して、開発用コンピューターに読み込まれないようにすることができます。

拡張機能をインストールするには

  1. Visual Studio のすべてのインスタンスを閉じます。

  2. 拡張機能プロジェクトのビルド出力フォルダーのをダブルクリックするか、ショートカット メニューを開いて、**[開く]**を選択して、.vsixファイルを開きます:

  3. [Visual Studio 拡張機能インストーラー] のダイアログ ボックスで、拡張機能をインストールする選択し、を [インストール] のボタンを選択します。Visual Studioのエディションは。

    拡張機能のファイルが %UserProfile%\AppData\Local\Microsoft\VisualStudio\11.0\Extensions\<作成者の名前>\<拡張機能の名前>\<バージョン> にインストールされます。このパスの最後の 3 つのフォルダーは、拡張機能の extension.vsixmanifest ファイル内の Author、Name、および Version の各要素から構築されます。

  4. Visual Studioの拡張機能をインストールしたら、[閉じる] のボタンをクリックします。

拡張機能をデバッグするには

  1. 管理者特権で Visual Studio を起動し、拡張機能プロジェクトを開きます。以下の手順では、Visual Studio のこのインスタンスを第 1 インスタンスと呼びます。

  2. Visual Studio の別のインスタンスを管理者特権で起動します。以下の手順では、Visual Studio のこのインスタンスを第 2 インスタンスと呼びます。

  3. Visual Studio の第 1 インスタンスに切り替えます。

  4. メニュー バーで、[デバッグ]、**[プロセスにアタッチ]**を選択します。

  5. [選択可能なプロセス] の一覧で、devenv.exeを選択します。これが、Visual Studio の第 2 インスタンスを表します。プロジェクトの拡張機能は、このインスタンスでデバッグすることになります。

  6. [アタッチ] のボタンをクリックします。

    Visual Studio によって拡張機能プロジェクトがデバッグ モードで実行されます。

  7. Visual Studio の第 2 インスタンスに切り替えます。

  8. 拡張機能を読み込む新しい SharePoint プロジェクトを作成します。たとえば、リスト定義プロジェクト項目の拡張機能をデバッグする場合は、[リスト定義] プロジェクトを作成します。

  9. 拡張機能のコードのテストに必要な手順をすべて実行します。

  10. 拡張機能のデバッグが完了したら、Visual Studio の第 2 インスタンスを閉じます。

拡張機能を削除するには

  1. Visual Studioで、メニュー バーで、[ツール]、**[拡張機能と更新プログラム]**を選択します。

    [拡張機能と更新プログラム] のダイアログ ボックスが表示されます。

  2. 拡張機能の一覧で、拡張機能の名前を選択し、[アンインストール] のボタンをクリックします。

  3. 表示されたダイアログ ボックスで、拡張機能をアンインストールすることを確認するに [○] のボタンをクリックします。

  4. アンインストールを実行するに [今すぐ再起動] のボタンをクリックします。

SharePoint コマンドのデバッグ

SharePoint ツールの拡張機能に属している SharePoint コマンドをデバッグする場合は、vssphost4.exe プロセスにデバッガーをアタッチする必要があります。これは、SharePoint コマンドを実行する 64 ビット ホスト プロセスです。SharePoint コマンドと vssphost4.exe の詳細については、「SharePoint オブジェクト モデルの呼び出し」を参照してください。

vssphost4.exe プロセスにデバッガーをアタッチするには

  1. 前に説明した手順に従って、Visual Studio の実験用インスタンスまたは Visual Studio の通常のインスタンスで拡張機能のデバッグを開始します。

  2. デバッガーでは、メニュー バーで実行するVisual Studioのインスタンスで、[デバッグ]、**[プロセスにアタッチ]**を選択します。

  3. [選択可能なプロセス] の一覧で、[vssphost.exe]を選択します。

    [!メモ]

    vssphost.exe が一覧に表示されない場合は、拡張機能を実行する Visual Studio のインスタンスで vssphost4.exe プロセスを開始する必要があります。通常、そのためには、Visual Studio によって開発コンピューター上の SharePoint サイトに接続する操作を実行します。たとえば、サーバー エクスプローラー ウィンドウの [SharePoint 接続] ノードの下にあるサイト接続ノード (サイトの URL を表示するノード) を展開する場合、または特定の SharePoint プロジェクト項目 (リスト インスタンス項目やイベント レシーバー項目など) を SharePoint プロジェクトに追加する場合に、Visual Studio では vssphost4.exe を開始します。

  4. [アタッチ] のボタンをクリックします。

  5. デバッグ対象の Visual Studio のインスタンスで、コマンドの実行に必要な手順を実行します。

SharePoint ツールの拡張機能のデバッグが簡単になるようにレジストリ値を変更する

Visual Studio の SharePoint ツールの拡張機能をデバッグする場合は、レジストリの値を変更すると、拡張機能のトラブルシューティングに役立ちます。値は HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\11.0\SharePointTools キーの下にあります。既定では、これらの値は存在しません。

SharePointツールの拡張機能をトラブルシューティングする場合は、EnableDiagnostics値を作成および設定できます。その値を次の表に示します。

価値

説明

EnableDiagnostics

診断メッセージを [出力] ウィンドウに表示するかどうかを指定する REG_DWORD です。

診断メッセージを表示する場合は、この値を 1 に設定します。メッセージを表示しないようにするには、この値を 0 に設定するか、または削除します。

SharePoint ツールの拡張機能からメッセージを [出力] ウィンドウに書き込むには、SharePoint プロジェクト サービスを使用します。詳細については、「SharePoint プロジェクト サービスの使用」を参照してください。

拡張機能にSharePointコマンドが含まれる場合は、コマンドのトラブルシューティングを行うことセットの追加の作成、値。それらの値を次の表に示します。

価値

説明

AttachDebuggerToHostProcess

vssphost4.exe の開始直後にデバッガーをアタッチできるダイアログ ボックスを表示するかどうかを指定する REG_DWORD です。これは、デバッグするコマンドが vssphost.exe の開始直後にそのプロセスによって実行され、コマンドが実行される前に手動でデバッガーをアタッチする時間がない場合に役立ちます。ダイアログ ボックスを表示するために、vssphost4.exe では、開始時に Debugger.Break メソッドを呼び出します。

この動作を有効にするには、この値を 1 に設定します。この動作を無効にするには、この値を 0 に設定するか、または削除します。

この値を 1 に設定すると、HostProcessStartupTimeout 値を増やすことが必要になる場合があります。これにより、vssphost4.exe が正常に開始されたことを Visual Studio に通知するまでの間に、ユーザーはデバッガーをアタッチできます。

ChannelOperationTimeout

SharePoint コマンドの実行を待機する時間 (秒単位) を指定する REG_DWORD です。時間内にコマンドが実行されない場合、SharePointConnectionException がスローされます。

既定値は 120 秒です。

HostProcessStartupTimeout

vssphost4.exe が正常に開始されたことを vssphost4.exe が通知するのを待機する時間 (秒単位) を指定する REG_DWORD です。時間内に vssphost4.exe から正常に開始されたことが通知されない場合、SharePointConnectionException がスローされます。

既定値は 60 秒です。

MaxReceivedMessageSize

Visual Studio と vssphost4.exe の間で渡される WCF メッセージの最大許容サイズ (バイト単位) を指定する REG_DWORD です。

既定値は 1,048,576 バイト (1 MB) です。

MaxStringContentLength

Visual Studio と vssphost4.exe の間で渡される文字列の最大許容サイズ (バイト単位) を指定する REG_DWORD です。

既定値は 1,048,576 バイト (1 MB) です。

参照

概念

Visual Studio での SharePoint ツールの拡張機能の配置

その他の技術情報

Visual Studio の SharePoint ツールの拡張