I've just tried the following code on fresh installation of Kentico 12 MVC and it worked well. I've added this class to CMSApp CMS project, into CMSModules folder:
using CMS.DataEngine;
using CMS.EventLog;
using CMS.OnlineForms;
using CMS.Scheduler;
using CMS.SiteProvider;
namespace CMSApp.CMSModules
{
public class CustomTask : ITask
{
public string Execute(TaskInfo ti)
{
var details = "Custom scheduled task executed. Task data: " + ti.TaskData;
EventLogProvider.LogInformation("CustomTask", "Execute", details);
var formObject = BizFormInfoProvider.GetBizFormInfo("DancingGoatMvcContactUsNew", SiteContext.CurrentSiteID);
if (formObject == null) return null;
var formClass = DataClassInfoProvider.GetDataClassInfo(formObject.FormClassID);
var formClassName = formClass.ClassName;
var data = BizFormItemProvider.GetItems(formClassName)
.WhereEmpty("TestText");
foreach (var item in data)
{
BizFormInfoProvider.DeleteBizFormRecordFiles(formClass.ClassFormDefinition, item, SiteContext.CurrentSiteName);
item.Delete();
}
return null;
}
}
}
This is how the task was configured in Kentico (registering custom class is not mandatory, you can just select ITask implementation from the assembly you are using):
data:image/s3,"s3://crabby-images/fb995/fb9958c230d0ed53956b5029fe9fff88bf85efab" alt="task config"
In the code I was using DancingGoatMvcContactUsNew as form code name:
data:image/s3,"s3://crabby-images/ad76a/ad76ad9da9f34ba6975b51b0d945295020a95694" alt="code name"
And this is the data before running the task:
data:image/s3,"s3://crabby-images/5bd1c/5bd1c724b68bf11480927f874378cb7cddcc21af" alt="data before"
This is after (you can see that all the records with empty Test text were removed):
data:image/s3,"s3://crabby-images/ebd29/ebd295ba425fad1bcd0e41e9ea0ec6f89f369da8" alt="data after"
The only other reason I can think of is that you may have some custom module that uses some Form events and cancels the delete operation or something, but that would have been strange..