我正在使用VersionOne SDK,并不断得到一个关于OID无效的错误。但是,当我使用该OID在VersionOne中查找测试时,它是测试的正确OID。
A first chance exception of type 'VersionOne.SDK.APIClient.OidException' occurred in VersionOne.SDK.APIClient.dll
Invalid OID token: Test:32423 我正在将一个包含"Test:32423“的字符串传递到方法中。
public void UpdateTestResults(string strTestId, string strActualResult)
{
var testId = Oid.FromToken(strTestId, _metaModel);
var query = new Query(testId);
var assetType = _metaModel.GetAssetType("Test");
var addResults = assetType.GetAttributeDefinition("ActualResults");
query.Selection.Add(addResults);
var result = _services.Retrieve(query);
var test = result.Assets[0];
var oldResult = GetValue(test.GetAttribute(addResults).Value);
var time = DateTime.Now;
const string format = "MMM ddd d HH:mm yyyy";
test.SetAttributeValue(addResults, "<p>" + "\n" + oldResult + time.ToString(format) + "-->" + strActualResult + "</p>");
_services.Save(test);
_logger.Log(Loglevel.Debug, test.Oid.Token, oldResult, GetValue(test.GetAttribute(addResults).Value));
}我注意到,只有在连续运行一系列测试时才会发生错误。当我只运行一个测试时,错误就不会发生。
这是我在类顶部放置的代码,用于创建连接器和构造函数。
const string ApplicationUrl = "https://www12.v1host.com/VersionOneAccount/";
readonly NetworkCredential _credentials = new NetworkCredential("userName", "passWord");
readonly IMetaModel _metaModel = new MetaModel(new VersionOneAPIConnector(ApplicationUrl + "meta.v1/"));
readonly IServices _services;
public V1Tools(ref DataObject masterData)
{
_services = new Services(_metaModel, new VersionOneAPIConnector(ApplicationUrl + "rest-1.v1/", _credentials));
_logger = masterData.Logger;
}发布于 2014-06-09 18:01:41
当我查看内部异常时,我发现请求正在超时,这将导致抛出Invalid OID异常。因此,如果OID是正确的,并且看到了这个错误,那么检查是否有另一个web请求干扰了应用程序和VersionOne服务器之间的通信。
https://stackoverflow.com/questions/23376000
复制相似问题