我的Web应用程序项目有一个自定义的TFS构建过程,该过程还进行发布。为了实现这一点,我尝试在从构建复制已编译的源之前删除当前发布位置。
这是有效的(大多数时候),除非文件被锁定,因为有人访问网站,这通常不是问题,因为大多数时候构建都是在没有人访问的情况下发生的(因为这些纯粹是开发和QA构建)。
为了尝试修复那些无法删除发布目录的边缘情况,我将app_offline.htm文件复制到该目录中,等待4秒钟后再尝试删除网站的其余部分。这是有效的,但是,当我尝试在发布完成后删除app_offline.htm时,我没有从这一步中得到任何错误。我得到以下错误:
无法取消工作流。需要重新启动代理。详细信息:无法执行该操作,因为WorkflowApplication f670d4fb-d9e3-4f33-bc3d-925faa925e04已中止。
删除是使用自定义CodeActivity创建的(因为TFS工作流没有删除)。
public sealed class DeleteFile : CodeActivity
{
// Define an activity input argument of type string
[RequiredArgument]
public InArgument<string> File { get; set; }
public InArgument<int?> Tries { get; set; }
// If your activity returns a value, derive from CodeActivity<TResult>
// and return the value from the Execute method.
protected override void Execute(CodeActivityContext context)
{
// Obtain the runtime value of the Text input argument
int tries = Tries.Get(context) ?? 1;
for (int i = 0; i < tries; i++)
{
try
{
System.IO.File.Delete(File.Get(context));
break;
}
catch (System.IO.IOException)
{
if (i == tries - 1)
throw;
Thread.Sleep(TimeSpan.FromSeconds(4));
}
}
}
}
我后来添加了“Tries”参数,试图找出导致此错误的原因。
但是,值得注意的是,在查看日志时,上面的错误不会放在DeleteFile活动下,而是只放在日志的顶部,并且没有其他错误或警告。
最后,我们的tfsbuild用户对发布目录具有删除权限(删除目录的其余部分没有问题,只删除app_offline.htm