Ошибка при извлечении метаданных в проекте docfx

Несмотря на чтение документации docfx и многочисленные проблемы с Github, я не могу заставить мой проект docfx работать.

Предпринятые шаги:

  1. Инициализировать корневой каталог docfx init -q
  2. Сборка из корневого каталога docfx build (без ошибок)
  3. обслуживать docfx "/user/docfx_project/docfx.json" --serve

Трассировки стека:

Error:Error extracting metadata for /user/docfx_project/src/MyApp/MyApp.csproj,/user/docfx_project/src/MyApp.Tests/MyApp.Tests.csproj: System.NullReferenceException: Object reference not set to an instance of an object
  at Microsoft.DocAsCode.Metadata.ManagedReference.ExtractMetadataWorker.SaveAllMembersFromCacheAsync () [0x00380] in <0779a76130d64c11baa2c8c084cbfe7c>:0 
  at Microsoft.DocAsCode.Metadata.ManagedReference.ExtractMetadataWorker.ExtractMetadataAsync () [0x000c0] in <0779a76130d64c11baa2c8c084cbfe7c>:0 

Окружающая обстановка:

  • OSX 10.13.6
  • docfx 2.56.2.0
  • Пакет SDK для.NET Core (3.1.401)
  • Моно JIT-компилятор версии 6.10.0.104

Структура проекта:

docfx-project
 |
 +-- _site
 +-- api
 +-- apidoc
 +-- articles
 +-- docfx.json
 +-- images
 +-- index.md
 +-- obj
 +-- src
     |
     +-- MyApp
         |
         +-- MyApp.csproj
 +-- toc.yml

docfx.json:

{
  "metadata": [
    {
      "src": [
        {
          "files": [
            "src/**/**.csproj"
          ]
        }
      ],
      "dest": "api",
      "disableGitFeatures": false,
      "disableDefaultFilter": false
    }
  ],
  "build": {
    "content": [
      {
        "files": [
          "api/**.yml",
          "api/index.md"
        ]
      },
      {
        "files": [
          "articles/**.md",
          "articles/**/toc.yml",
          "toc.yml",
          "*.md"
        ]
      }
    ],
    "resource": [
      {
        "files": [
          "images/**"
        ]
      }
    ],
    "overwrite": [
      {
        "files": [
          "apidoc/**.md"
        ],
        "exclude": [
          "obj/**",
          "_site/**"
        ]
      }
    ],
    "dest": "_site",
    "globalMetadataFiles": [],
    "fileMetadataFiles": [],
    "template": [
      "default"
    ],
    "postProcessors": [],
    "markdownEngineName": "markdig",
    "noLangKeyword": false,
    "keepFileLink": false,
    "cleanupCacheHistory": false,
    "disableGitFeatures": false
  }
}

Halp.

1 ответ

У меня относительно слабое представление о том, почему это работает, но то, что потребовалось на моей машине CI, было export VSINSTALLDIR=- иными словами, очистка VSINSTALLDIRпеременная среды перед запуском docfx metadata. Я считаю, что это влияет на версию msbuild (или, по крайней мере, на некоторые файлы msbuild), которую использует docfx.

Это было исправлением для других проблем в прошлом - одна из них утверждает, что была исправлена ​​некоторое время назад, но похоже, что тот же обходной путь работает и для этой проблемы... по крайней мере, на моей машине CI.

Другие вопросы по тегам