Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Eternal restore loop when version is dynamically generated #1457

Open
abpiskunov opened this issue Feb 3, 2017 · 50 comments
Open

Eternal restore loop when version is dynamically generated #1457

abpiskunov opened this issue Feb 3, 2017 · 50 comments
Labels
Bug This is a functional issue in already written code. Feature-NuGet NuGet integration including pushing it properties, project and package references, and Pack support. Performance-Scenario-General This issue affects performance in general. Tenet-Performance This issue affects the "Performance" tenet. Triage-Investigate Reviewed and investigation needed by dev team
Projects
Milestone

Comments

@abpiskunov
Copy link
Contributor

abpiskunov commented Feb 3, 2017

Open solution in this zip file: \\vwdbuild01\Temp\antonpis\repro\RestoreLoopRepro.zip. It would start restore, restore fails and would start again - never stopping restore loop.

I saw that on VS d15rel 26131.1.

@abpiskunov
Copy link
Contributor Author

@srivatsn @davkean FYI, not sure if it is known , but probably would be release blocking ...

@srivatsn srivatsn added Blocking-Release We cannot ship the current milestone without this feature. Bug This is a functional issue in already written code. labels Feb 3, 2017
@srivatsn srivatsn added this to the 1.0 RTM milestone Feb 3, 2017
@natidea
Copy link
Contributor

natidea commented Feb 4, 2017

@abpiskunov I don't see this problem on d15rel.26202.1. Can you confirm it is fixed for you in that build? Closing for now.

@natidea natidea closed this as completed Feb 4, 2017
@davkean davkean reopened this Feb 4, 2017
@davkean
Copy link
Member

davkean commented Feb 4, 2017

We've got another repro of this, more details forthcoming.

@mikeharder
Copy link

mikeharder commented Feb 4, 2017

It repros for me on 15.0.26202.1 D15REL. Repro project at https://github.com/mikeharder/HelloWorldNetCoreApp2.

One thing unusual about the repro project is TargetFramework=netcoreapp2.0 and RuntimeFrameworkVersion=2.0.0-*.

@mikeharder
Copy link

dotnet restore from the command line works fine:

> dotnet --info
.NET Command Line Tools (1.0.0-rc4-004755)

Product Information:
 Version:            1.0.0-rc4-004755
 Commit SHA-1 hash:  bffbee2b91

Runtime Environment:
 OS Name:     Windows
 OS Version:  6.3.9600
 OS Platform: Windows
 RID:         win81-x64
 Base Path:   C:\Program Files\dotnet\sdk\1.0.0-rc4-004755

> dotnet restore
  Restoring packages for D:\Git\HelloWorldNetCoreApp2\HelloWorldNetCoreApp2.csproj...
  Generating MSBuild file D:\Git\HelloWorldNetCoreApp2\obj\HelloWorldNetCoreApp2.csproj.nuget.g.props.
  Generating MSBuild file D:\Git\HelloWorldNetCoreApp2\obj\HelloWorldNetCoreApp2.csproj.nuget.g.targets.
  Writing lock file to disk. Path: D:\Git\HelloWorldNetCoreApp2\obj\project.assets.json
  Restore completed in 162.53 ms for D:\Git\HelloWorldNetCoreApp2\HelloWorldNetCoreApp2.csproj.

  NuGet Config files used:
      D:\Git\HelloWorldNetCoreApp2\NuGet.Config
      C:\Users\<user>\AppData\Roaming\NuGet\NuGet.Config
      C:\Program Files (x86)\NuGet\Config\Microsoft.VisualStudio.Offline.config

  Feeds used:
      https://dotnet.myget.org/F/dotnet-core/api/v3/index.json
      https://api.nuget.org/v3/index.json

@mikeharder
Copy link

Build error in VS:

Severity: Error
Code: MSB4062
Description: The "HandlePackageFileConflicts" task could not be loaded from the assembly C:\Users\mharder\.nuget\packages\netstandard.library\2.0.0-beta-24918-03\build\desktop/NETStandard.Tools.dll. Could not load file or assembly 'NETStandard.Tools, Version=999.999.999.999, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51' or one of its dependencies. Strong name validation failed. (Exception from HRESULT: 0x8013141A) Confirm that the <UsingTask> declaration is correct, that the assembly and all its dependencies are available, and that the task contains a public class that implements Microsoft.Build.Framework.ITask.
Project: HelloWorldNetCoreApp2
File: C:\Users\<username>\.nuget\packages\netstandard.library\2.0.0-beta-24918-03\build\NETStandard.Library.targets
Line: 80

Output Window:

Restoring NuGet packages...
Time Elapsed: 00:00:00.0075856
========== Finished ==========

Restoring NuGet packages...
Time Elapsed: 00:00:00.0586642
========== Finished ==========

Restoring NuGet packages...
Time Elapsed: 00:00:00.0071143
========== Finished ==========

@mikeharder
Copy link

mikeharder commented Feb 4, 2017

The "HandlePackageFileConflicts" task could not be loaded from the assembly
C:\Users\<user>\.nuget\packages\netstandard.library\2.0.0-beta-24918-03\build\desktop/NETStandard.Tools.dll.
Could not load file or assembly 'NETStandard.Tools, Version=999.999.999.999, Culture=neutral, PublicKeyToken=cc7b13ffcd2ddd51'
or one of its dependencies.
Strong name validation failed. (Exception from HRESULT: 0x8013141A)

Perhaps the root cause in my repro, is that the netstandard.library package being used is not signed?

@abpiskunov
Copy link
Contributor Author

@natidea try to remove all obj/bin/.vs folders form teh solution form all projects, close VS and open solution again - that worked for me everytime to get that repro

@mikeharder
Copy link

@natidea @abpiskunov: The solution from Anton does not repro on my install of 15.0.26202.1 D15REL.

@eerhardt
Copy link
Member

eerhardt commented Feb 4, 2017

@ericstj @weshaggard for the signing of the net standard package

@natidea
Copy link
Contributor

natidea commented Feb 4, 2017

I was able to repro with @mikeharder 's project, but still can't repro with Anton's. Issue went away when I switched target framework to netcoreapp1.0

@natidea
Copy link
Contributor

natidea commented Feb 4, 2017

Stepping through @mikeharder 's project in a debugger, I see an infinite loop of subscription updates with the following sequence of changes to PackageReferences:

  • Added: Microsoft.NETCore.App
  • Removed: Microsoft.NETCore.App
  • Added: Microsoft.NETCore.App
  • Removed: Microsoft.NETCore.App
    ...

And so on. Each time this changes, we nominate NuGet to do a new restore.

@natidea
Copy link
Contributor

natidea commented Feb 6, 2017

I'm no longer seeing this on my machine. I noticed that the NETStandard.Library package was updated to 2.0.0-beta-25006-01 and the binaries are signed in this build, whereas they were not signed in the build I was using last week: 2.0.0-beta-24918-03.

@weshaggard can you confirm the signing issue was fixed?

@davkean
Copy link
Member

davkean commented Feb 6, 2017

Regardless of whether the signing issue was fixed, we should make it so that we never get into this state if there are bad packages.

@weshaggard
Copy link
Member

Yes the signing issue was fixed but I agree with @davkean we should guard against this as any nuget package could potentially get us into this state.

@natidea
Copy link
Contributor

natidea commented Feb 7, 2017

/cc some NuGet folks for ideas on how a failures during restore could lead to project state changing in a way that produces this infinite loop. @emgarten @alpaix @rrelyea

I'll note that the task that failed (HandlePackageFileConflicts) is taking a direct dependency on our SDK targets:

<HandlePackageFileConflictsAfter>ResolvePackageDependenciesForBuild</HandlePackageFileConflictsAfter>

It seems likely that only packages with tasks that participate in this part of the build could put us in this broken state i.e. mostly our packages and partner teams. I'll drop the blocking release label.

@natidea natidea removed the Blocking-Release We cannot ship the current milestone without this feature. label Feb 7, 2017
@srivatsn srivatsn modified the milestones: 1.1, 1.0 RTM Feb 9, 2017
@atanasa
Copy link

atanasa commented Feb 17, 2017

I am experiencing an endless loop of restores in VS 2017 RC4+26206.0 when switching to a custom solution configuration. I have 3 solution configurations - Debug, Restore, Interop. Once I switch to the Interop configuration it would start doing restore in an endless loop. There are no errors just a repeating restore operation every second.

I am having trouble isolating this. Is there some way to turn on diagnostics? I have changed the verbosity for Build and Run in Options to Diagnostic but this does not seem to affect the restore output.

@atanasa
Copy link

atanasa commented Feb 17, 2017

I have managed to get an isolated repro for my case. The repro solution:
ReproEternalRestore.zip

This is the project:

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
    <InteropVersion>$([System.DateTime]::Now.ToString(yyyyMMdd.HHmmss))</InteropVersion>
    <PackageVersion Condition=" '$(Configuration)' == 'Interop' ">$(InteropVersion)</PackageVersion>
  </PropertyGroup>
  <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Interop|AnyCPU'" />
  <PropertyGroup>
    <TargetFramework>netstandard1.4</TargetFramework>
  </PropertyGroup>

</Project>

I would probably be able to workaround it by taking this into a post build action. It is strange that a change in the package version would trigger a restore as this is the version of the output package not the input dependencies. Also it seems that this is evaluated very often.

@rrelyea
Copy link

rrelyea commented Feb 17, 2017

PackageVersion gets written in the assets file, as that is where "dotnet pack" will get the appropriate version to reference as a package, for projectreferences.
Roslyn project system has package version as a property that NuGet restore cares about, and nominates its project for a restore whenever it changes.

/cc: @alpaix @rohit21agrawal

@jmarolf jmarolf removed this from To do in jmarolf Jul 24, 2019
@nkolev92
Copy link
Contributor

@jmarolf jmarolf added this to the Backlog milestone Mar 9, 2020
@jmarolf jmarolf added the Triage-Investigate Reviewed and investigation needed by dev team label Mar 9, 2020
@jmarolf jmarolf removed their assignment Mar 9, 2020
@chanibal
Copy link

Had this issue with VS 2019 16.5.5: details on Stack Overflow, someone also had this on MS Developer Community.

@aesalazar
Copy link

This is still an issure in VS 2019 16.6. I had this in all of my csproj files which triggered the issue:

<FileVersion>1.0.$([System.DateTime]::UtcNow.Date.Subtract($([System.DateTime]::Parse("2000-01-01"))).TotalDays).$([System.Math]::Floor($([MSBuild]::Divide($([System.DateTime]::UtcNow.TimeOfDay.TotalSeconds), 1.32))))</FileVersion>
<Version>1.0.$([System.DateTime]::UtcNow.Date.Subtract($([System.DateTime]::Parse("2000-01-01"))).TotalDays).$([System.Math]::Floor($([MSBuild]::Divide($([System.DateTime]::UtcNow.TimeOfDay.TotalSeconds), 1.32))))</Version>

I was able to resolve it by backing off the Version to NOT include the seconds suffix:

<FileVersion>1.0.$([System.DateTime]::UtcNow.Date.Subtract($([System.DateTime]::Parse("2000-01-01"))).TotalDays).$([System.Math]::Floor($([MSBuild]::Divide($([System.DateTime]::UtcNow.TimeOfDay.TotalSeconds), 1.32))))</FileVersion>
<Version>1.0.$([System.DateTime]::UtcNow.Date.Subtract($([System.DateTime]::Parse("2000-01-01"))).TotalDays)</Version>

but still keep it on the FileVersion.

@dominoFire
Copy link

Another report: https://developercommunity.visualstudio.com/content/problem/1173352/if-csproj-has-dynamic-versionsuffix-nuget-restore.html

@drewnoakes drewnoakes changed the title Eternal restore loop Eternal restore loop when version is dynamically generated Sep 17, 2020
@ben-page
Copy link

This is still an issue in 16.8.1

@kartheekp-ms
Copy link

kartheekp-ms commented Dec 11, 2020

@RamjotSingh from Teams team has reported this issue through a VS feedback ticket. Any user action such as adding a class file, editing code in the IDE triggered a restore through project system nomination. The project had their patch version number set to
<SemanticVersionPatch>$([MSBuild]::Divide($([System.DateTime]::Now.Subtract($([System.DateTime]::Parse($(SemanticVersionDate)))).TotalMinutes), 5).ToString('F0'))</SemanticVersionPatch> this behavior in the IDE.

@nkolev92 suggested a fix to this setting and there were no continuous restores after that.

https://developercommunity2.visualstudio.com/t/Performance-issues-in-Visual-Studio-168/1280509

@visschersm
Copy link

visschersm commented Aug 5, 2021

A workaround I found is to not have the version change during design-time builds. Using the advice from design-time-builds.md I made it only add the date when not a design-time build.

I tried using this as well. But my dynamic version does not get set at buildtime either.

<PropertyGroup Condition="'$(DesignTimeBuild)' == 'false' OR '$(BuildingProject)' != 'true'">
    <MajorVersion>0</MajorVersion>
    <MinorVersion>0</MinorVersion>
    <PatchVersion>$([System.DateTime]::Now.ToString("yyMMdd"))</PatchVersion>
    <BuildVersion>$([System.DateTime]::Now.ToString("HHmmss"))</BuildVersion>
    <PackageVersion>$(MajorVersion).$(MinorVersion).$(PatchVersion).$(BuildVersion)</PackageVersion>
</PropertyGroup>

I noticed the note but with or without the false check it did not matter.

NOTE: The DesignTimeBuild property is typically empty ('') in normal builds, so avoid comparisons to 'false'.

Neither did setting the Target. (After/Before Targets)

<Target Name="AddAdditionalReferences" AfterTargets="ResolveAssemblyReferences">
...
</Target>

Any help would be appreciated since this seems to be the best current solution for this problem.

@shmuelie
Copy link

shmuelie commented Aug 5, 2021

@visschersm The logic I created was this (the git stuff is from GitInfo)

<Target Name="SetVersion" AfterTargets="_GitPopulateVersionInfo" BeforeTargets="CoreBuild">
    <PropertyGroup Condition="'$(VersionSuffix)' == ''">
      <VersionSuffix>0-alpha</VersionSuffix>
      <VersionSuffix Condition="'$(DesignTimeBuild)' != 'true' OR '$(BuildingProject)' == 'true'">$(VersionSuffix)-$([System.DateTime]::UtcNow.ToString('yyyyMMddHHmmss'))</VersionSuffix>
    </PropertyGroup>
    <PropertyGroup>
      <VersionSuffix Condition="'$(GitBranch)' != 'master' AND '$(GitBranch)' != '' AND '$(GitBranch.StartsWith(tags/release/))' == 'false'">$(VersionSuffix)-$(GitBranch.Replace("/", "-").Replace("_", "-").Split("^")[0])</VersionSuffix>
      <Version>$(VersionPrefix)</Version>
      <PackageVersion>$(VersionPrefix).$(VersionSuffix)</PackageVersion>
      <AssemblyVersion>$(VersionPrefix)</AssemblyVersion>
    </PropertyGroup>
    <PropertyGroup Condition="$(VersionSuffix.Contains('-'))">
      <FileVersion>$(AssemblyVersion).0</FileVersion>
    </PropertyGroup>
    <PropertyGroup Condition="!$(VersionSuffix.Contains('-'))">
      <FileVersion>$(PackageVersion)</FileVersion>
    </PropertyGroup>
  </Target>

@visschersm
Copy link

@shmuelie Thanks for sharing!

got it to work like this:

<Target Name="SetVersion" BeforeTargets="Build">
    <PropertyGroup>
      <MajorVersion>0</MajorVersion>
      <MinorVersion>0</MinorVersion>
      <PatchVersion>$([System.DateTime]::Now.ToString("yyMMdd"))</PatchVersion>
      <BuildVersion  Condition="'$(DesignTimeBuild)' != 'true' OR '$(BuildingProject)' == 'true'">$([System.DateTime]::Now.ToString("HHmmss"))</BuildVersion>
      <PackageVersion>$(MajorVersion).$(MinorVersion).$(PatchVersion).$(BuildVersion)</PackageVersion>
    </PropertyGroup>
  </Target>

@donnie-msft
Copy link

@kvenkatrajan kvenkatrajan added this to Triage - Aged - Validate in Triage Apr 14, 2022
@captainjono
Copy link

Im getting an infinite restore loop that does not have a project with a VersionSuffix. i do have a conditional FileVersion in a project thats unloaded but who knows. cant really be bothered to write a real bug report other then its a pain in my ass!

I write this incase someone else comes across it, even though i had automatic restores disabled, i had to also remove BOTH checkboxs on this options page to fix the issue.

image

Microsoft Visual Studio Enterprise 2022
Version 17.3.0 Preview 1.0
VisualStudio.17.Preview/17.3.0-pre.1.0+32505.426
Microsoft .NET Framework
Version 4.8.03752

Installed Version: Enterprise

Architecture Diagrams and Analysis Tools   00476-80000-00000-AA788
Microsoft Architecture Diagrams and Analysis Tools

Visual C++ 2022   00476-80000-00000-AA788
Microsoft Visual C++ 2022

.NET Core Debugging with WSL   1.0
.NET Core Debugging with WSL

ADL Tools Service Provider   1.0
This package contains services used by Data Lake tools

ASA Service Provider   1.0

ASP.NET and Web Tools 2019   17.3.122.33185
ASP.NET and Web Tools 2019

Azure App Service Tools v3.0.0   17.3.122.33185
Azure App Service Tools v3.0.0

Azure Data Lake Tools for Visual Studio   2.6.5000.0
Microsoft Azure Data Lake Tools for Visual Studio

Azure Functions and Web Jobs Tools   17.3.122.33185
Azure Functions and Web Jobs Tools

Azure Stream Analytics Tools for Visual Studio   2.6.5000.0
Microsoft Azure Stream Analytics Tools for Visual Studio

C# Tools   4.3.0-1.22254.1+9919d7e7bd753404a5d2328e5e3fb2de635169f3
C# components used in the IDE. Depending on your project type and settings, a different version of the compiler may be used.

Common Azure Tools   1.10
Provides common services for use by Azure Mobile Services and Microsoft Azure Tools.

Dotfuscator Community Edition   6.5.0+76d4669002
PreEmptive Protection - Dotfuscator CE

Extensibility Message Bus   1.2.6 (master@34d6af2)
Provides common messaging-based MEF services for loosely coupled Visual Studio extension components communication and integration.

Microsoft Azure Hive Query Language Service   2.6.5000.0
Language service for Hive query

Microsoft Azure Stream Analytics Language Service   2.6.5000.0
Language service for Azure Stream Analytics

Microsoft Azure Tools for Visual Studio   2.9
Support for Azure Cloud Services projects

Microsoft JVM Debugger   1.0
Provides support for connecting the Visual Studio debugger to JDWP compatible Java Virtual Machines

Mono Debugging for Visual Studio   17.3.7 (c1ffb2a)
Support for debugging Mono processes with Visual Studio.

Node.js Tools   1.5.40427.1 Commit Hash:d6dd02cc1b56ad1cb24b4ef0c48a81a985bbc64c
Adds support for developing and debugging Node.js apps in Visual Studio

NuGet Package Manager   6.3.0
NuGet Package Manager in Visual Studio. For more information about NuGet, visit https://docs.nuget.org/

Razor (ASP.NET Core)   17.0.0.2222701+751db1ebea5e6a9ecc7fa57fe447180422afa610
Provides languages services for ASP.NET Core Razor.

SQL Server Data Tools   17.0.62204.01010
Microsoft SQL Server Data Tools

ToolWindowHostedEditor   1.0
Hosting json editor into a tool window

TypeScript Tools   17.0.10420.2001
TypeScript Tools for Microsoft Visual Studio

Visual Basic Tools   4.3.0-1.22254.1+9919d7e7bd753404a5d2328e5e3fb2de635169f3
Visual Basic components used in the IDE. Depending on your project type and settings, a different version of the compiler may be used.

Visual F# Tools   17.1.0-beta.22178.3+6da0245a7ce4bb8483b8d1f2993c8ecaea967ad9
Microsoft Visual F# Tools

Visual Studio IntelliCode   2.2
AI-assisted development for Visual Studio.

VisualStudio.DeviceLog   1.0
Information about my package

VisualStudio.Mac   1.0
Mac Extension for Visual Studio

VSColorOutput64   2022.2
Color output for build and debug windows - https://mike-ward.net/vscoloroutput

VSPackage Extension   1.0
VSPackage Visual Studio Extension Detailed Info

WiX Toolset Visual Studio Extension   1.0.0.18
WiX Toolset Visual Studio Extension version 1.0.0.18
Copyright (c) .NET Foundation and contributors. All rights reserved.

Xamarin   17.3.0.91 (main@7802af5)
Visual Studio extension to enable development for Xamarin.iOS and Xamarin.Android.

Xamarin Designer   17.3.0.30 (remotes/origin/main@fb6442dc1)
Visual Studio extension to enable Xamarin Designer tools in Visual Studio.

Xamarin Templates   17.2.15 (2e3b60e)
Templates for building iOS, Android, and Windows apps with Xamarin and Xamarin.Forms.

Xamarin.Android SDK   12.3.99.58 (main/64b22fc)
Xamarin.Android Reference Assemblies and MSBuild support.
    Mono: adf1bc4
    Java.Interop: xamarin/java.interop/release/6.0.3xx@2a882d2d
    ProGuard: Guardsquare/proguard/v7.0.1@912d149
    SQLite: xamarin/sqlite/3.38.2@7b1e016
    Xamarin.Android Tools: xamarin/xamarin-android-tools/main@fc3c2ac


Xamarin.iOS and Xamarin.Mac SDK   15.11.0.87 (406f3098e)
Xamarin.iOS and Xamarin.Mac Reference Assemblies and MSBuild support.

@kzu
Copy link

kzu commented May 24, 2022

For folks doing dynamic version numbers, I'd suggest you just use 42.42.42 for Version for anything where $(CI) != 'true. There's really very little (no?) benefits from having those for local builds, in my experience. I used to be on the camp of "clone a release branch, build, have the 'exact' same bits, including version #s", but realized it's pointless. Never gave me anything but headaches.

So, fixed version number for local builds FTW. My 2cents :)

@melvyniandrag
Copy link

melvyniandrag commented Jun 1, 2022

I have an issue/temp fix just like @captainjono . No dynamic version numbers over here. Project stuck in an infinite nuget restore loop.

I unchecked the two things he unchecked but doesn't 100% resolve our issue. At least the infinite loop stops, but then we get sporadic build errors. Most common one is about Microsoft Store Engagement v10 missing - but its not, it's clearly installed, and the project has been compiling just fine for the last 3 years. A variety of other errors popup.

To be able to compile again our current work around is:

  1. delete obj/bin files
  2. Tools>Nuget package manager > package manager console the run dotnet restore
  3. restart vs
  4. restart PC
  5. Try compiling. Doesn't work? Go to number 1 and repeat until it compiles or we reach end of the work day.

Hope to see a fix soon! Will try to find time to build a small sample app, but probably wont have time for that in the near future.

@drewnoakes
Copy link
Member

@melvyniandrag sounds like you are seeing a different issue. Could you please use the Report a Problem feature in VS and attach a recording of the problem happening? Without a repro, that's the most likely way of getting the issue understood and fixed.

Alternatively, create a copy of your solution and start removing projects and source until you are left with a minimal repro. Restore happens at a project level, and I doubt your .cs files play a part. It's likely just a .csproj file that's needed here for a repro.

@seansparkman
Copy link

@drewnoakes I am seeing the original feedback for this problem, but it's closed. Should I open a new issue if I am still seeing this issue?

@drewnoakes
Copy link
Member

@seansparkman if you are using a dynamically generated version, then adding a feedback ticket would not be of much use. The problem is understood, and we don't consider it a supported scenario. Perhaps you could share the way you assign the version here, and we may be able to provide a workaround.

If however you see a restore loop without having a dynamic version then yes, a feedback ticket with a recording of the problem occurring would be welcome.

@drewnoakes drewnoakes added Tenet-Performance This issue affects the "Performance" tenet. Performance-Scenario-General This issue affects performance in general. labels Oct 19, 2023
@drewnoakes
Copy link
Member

See also #9142, which is a dupe (but more focussed and with suggestions on how to address this.)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug This is a functional issue in already written code. Feature-NuGet NuGet integration including pushing it properties, project and package references, and Pack support. Performance-Scenario-General This issue affects performance in general. Tenet-Performance This issue affects the "Performance" tenet. Triage-Investigate Reviewed and investigation needed by dev team
Projects
No open projects
Triage
Triage - Aged - Validate
Development

No branches or pull requests