How to step up TFS 2015 Update 2 to delete artifacts when build is deleted?
Is this possible?
EDIT: Add retention screen shot
I am using the default retention policy but it is NOT deleting artifacts from the drive.
EDIT: Add Copy and Publish Build Artifacts
EDIT: Add Working Folder
I added a powershell to display all environment variables and it said my workingFolder = E:TfsBuilds\Agent1_WorkPlace\5\s
Do you a powershell to set workingFolder to default?
Here is the file structure i have:
I am making an assumption here that we know that TFS2015 Update2 does not support this out of the box and that MS claims to have resolved this in TFS15.
I am going to paste the whole program for everyone's benefit. This code works and I am using it. I run this utility to clean the build artifactdrop location for builds that have been wiped out of TFS. The assumption we are making is that we are going to call the exe with two parameters that are folder paths:
where TFSDropLocation is where TFS is dropping the build artifacts and DumpFolderBeforeIDeleteThis is a folder where I collect all builds before I delete them forever. We could have deleted them right from TFSDropLocation but I like this additional step where we remove them to a separate location so that just in case, we happen to need them, they are their or alternately delete them from this location after one more round of verification -if that makes you comfortable.
If you specify build retention policies, retention policies will delete the items below:
More details you can refer a similar question in SO: Should artifacts associated with a build record be deleted when the build record is deleted?
Moreover, if you manually delete the build, everything of the build will be deleted.
Update
For now, server drops are deleted when a build is deleted but drops to UNC shares are not. It's also a known issue: Build.Preview - Drop Folder not deleted when build is deleted
If so, you may have to delete them manually.
Update2
I was wondering did you missed up the working folder with the drop folder. The default work folder location is a _work folder directly under the agent installation directory. The files in this folder will always keep or deleted until next build triggered. You can find the directory in your build log to double check this. More details please refer the definition from MSDN.
Update3
Each agent will have their own work folder. Such as XXX\Agent1, XXX\Agent2,...XXX\Agent6. I think the issue is that you are confusing the file structure.
With your file structure, the files which deployed to the server is copying to the folder called XXX\builds. However, these files are not the published Artifacts. There are something like temporary files. If you want to auto delete the files under the builds, you can add a Delete files task. at the last step. Even if these files are deleted during the build. You can still download the artifacts from server after build finished.