119 references to BuildRequest
Microsoft.Build (119)
BackEnd\Components\Scheduler\SchedulableRequest.cs (10)
344BlockingRequestKey key = new BlockingRequestKey(blockingRequest.BuildRequest); 468public bool IsProxyBuildRequest() => BuildRequest.IsProxyBuildRequest(); 519SchedulableRequest alternateRequest = _schedulingData.GetBlockedRequestIfAny(blockingRequest.BuildRequest.GlobalRequestId); 534if (requestToEvaluate.BuildRequest.GlobalRequestId == this.BuildRequest.GlobalRequestId) 545requestToEvaluate = _schedulingData.GetBlockedRequestIfAny(requestToEvaluate.BuildRequest.GlobalRequestId); 595if (currentRequest.BuildRequest.GlobalRequestId == blockingRequest.BuildRequest.GlobalRequestId) 616BlockingRequestKey key = new BlockingRequestKey(requestWeAreBlockedBy.BuildRequest); 633throw new SchedulerCircularDependencyException(requestCausingFailure.BuildRequest, ancestors);
BackEnd\Components\Scheduler\Scheduler.cs (71)
342return request.BuildRequest; 394TraceScheduler($"Circular dependency caused by request {ex.Request.GlobalRequestId}({ex.Request.ConfigurationId}) (nr {ex.Request.NodeRequestId}), parent {parentRequest.BuildRequest.GlobalRequestId}({parentRequest.BuildRequest.ConfigurationId}) (nr {parentRequest.BuildRequest.NodeRequestId})"); 395responses.Add(ScheduleResponse.CreateCircularDependencyResponse(nodeId, parentRequest.BuildRequest, ex.Request)); 407TraceScheduler($"Circular dependency caused by request {ex.Request.GlobalRequestId}({ex.Request.ConfigurationId}) (nr {ex.Request.NodeRequestId}), parent {parentRequest.BuildRequest.GlobalRequestId}({parentRequest.BuildRequest.ConfigurationId}) (nr {parentRequest.BuildRequest.NodeRequestId})"); 408responses.Add(ScheduleResponse.CreateCircularDependencyResponse(nodeId, parentRequest.BuildRequest, ex.Request)); 446ErrorUtilities.VerifyThrow(result.ParentGlobalRequestId == request.Parent.BuildRequest.GlobalRequestId, "Result's parent doesn't match request's parent."); 455ScheduleResponse response = TrySatisfyRequestFromCache(request.Parent.AssignedNode, request.BuildRequest, skippedResultsDoNotCauseCacheMiss: _componentHost.BuildParameters.SkippedResultsDoNotCauseCacheMiss()); 483if (unscheduledRequest.BuildRequest.GlobalRequestId == result.GlobalRequestId) 485TraceScheduler($"Request {unscheduledRequest.BuildRequest.GlobalRequestId} (node request {unscheduledRequest.BuildRequest.NodeRequestId}) also satisfied by result."); 486BuildResult newResult = new BuildResult(unscheduledRequest.BuildRequest, result, null); 499ScheduleResponse response = TrySatisfyRequestFromCache(parentNode, unscheduledRequest.BuildRequest, skippedResultsDoNotCauseCacheMiss: true); 504LogRequestHandledFromCache(unscheduledRequest.BuildRequest, response.BuildResult); 526_noLoggingCompletedSubmissionDetails = $"SubmissionId: {unscheduledRequest.BuildRequest.SubmissionId}; BuildRequestDataFlags: {unscheduledRequest.BuildRequest.BuildRequestDataFlags}"; 622if (request.BuildRequest.SubmissionId == submissionId) 910ReadSchedulingPlan(_schedulingData.GetRequestsByHierarchy(null).First().BuildRequest.SubmissionId); 1005SchedulingPlan.PlanConfigData configToConsider = _schedulingPlan.GetConfiguration(request.BuildRequest.ConfigurationId); 1038AssignUnscheduledRequestsToInProcNode(responses, idleNodes, request => IsTraversalRequest(request.BuildRequest)); 1139int requiredNodeId = _schedulingData.GetAssignedNodeForRequestConfiguration(unscheduledRequest.BuildRequest.ConfigurationId); 1143System.IO.FileInfo f = new FileInfo(_configCache[unscheduledRequest.BuildRequest.ConfigurationId].ProjectFullPath); 1181int requiredNodeId = _schedulingData.GetAssignedNodeForRequestConfiguration(unscheduledRequest.BuildRequest.ConfigurationId); 1185System.IO.FileInfo f = new FileInfo(_configCache[unscheduledRequest.BuildRequest.ConfigurationId].ProjectFullPath); 1223BuildRequest currentRequest = currentSchedulableRequest.BuildRequest; 1397int requiredNodeId = _schedulingData.GetAssignedNodeForRequestConfiguration(request.BuildRequest.ConfigurationId); 1409TraceScheduler($"Chose not to assign request {request.BuildRequest.GlobalRequestId} to node {nodeId} because its count of configurations ({configurationCountsByNode[nodeId]}) exceeds the current limit ({configurationCountLimit})."); 1431bool mustSendConfigurationToNode = _availableNodes[nodeId].AssignConfiguration(request.BuildRequest.ConfigurationId); 1435BuildRequestConfiguration config = _configCache[request.BuildRequest.ConfigurationId]; 1443responses.Add(ScheduleResponse.CreateScheduleResponse(nodeId, request.BuildRequest, mustSendConfigurationToNode)); 1444TraceScheduler($"Executing request {request.BuildRequest.GlobalRequestId} on node {nodeId} with parent {(request.Parent == null ? -1 : request.Parent.BuildRequest.GlobalRequestId)}"); 1521NodeAffinity affinity = GetNodeAffinityForRequest(request.BuildRequest); 1558int assignedNodeForConfiguration = _schedulingData.GetAssignedNodeForRequestConfiguration(request.BuildRequest.ConfigurationId); 1568NodeAffinity affinityRequired = GetNodeAffinityForRequest(request.BuildRequest); 1684_resultsCache.AddResult(new BuildResult(request.BuildRequest, new BuildAbortedException())); 1711blockingRequest.BuildRequest.ConfigurationId == blockedRequest.BuildRequest.ConfigurationId && 1730BuildRequest newRequest = new BuildRequest(parentRequest.BuildRequest.SubmissionId, BuildRequest.ResultsTransferNodeRequestId, parentRequest.BuildRequest.ConfigurationId, [], null, parentRequest.BuildRequest.BuildEventContext, parentRequest.BuildRequest, parentRequest.BuildRequest.BuildRequestDataFlags); 1742BuildRequestConfiguration configuration = _configCache[parentRequest.BuildRequest.ConfigurationId]; 1825existingRequestAffinity = GetNodeAffinityForRequest(existingRequest.BuildRequest); 1876responses.Add(ScheduleResponse.CreateResumeExecutionResponse(parentRequest.AssignedNode, parentRequest.BuildRequest.GlobalRequestId)); 1901TraceScheduler($"Unblocking request {request.BuildRequest.GlobalRequestId} on node {nodeId}"); 1904ScheduleResponse response = ScheduleResponse.CreateResumeExecutionResponse(nodeId, request.BuildRequest.GlobalRequestId); 1921ScheduleResponse response = TrySatisfyRequestFromCache(nodeForResults, request.BuildRequest, skippedResultsDoNotCauseCacheMiss: _componentHost.BuildParameters.SkippedResultsDoNotCauseCacheMiss()); 1927LogRequestHandledFromCache(request.BuildRequest, response.BuildResult); 1938LogRequestHandledFromCache(request.BuildRequest, response.Unblocker.Result); 1941TraceScheduler($"Reporting results for request {request.BuildRequest.GlobalRequestId} with parent {request.BuildRequest.ParentGlobalRequestId} to node {response.NodeId} from cache."); 1956CheckIfCacheMissOnReferencedProjectIsAllowedAndErrorIfNot(nodeForResults, request.BuildRequest, responses, emitNonErrorLogs: false); 2106if (blockedRequest.BuildRequest.GlobalRequestId == request.ParentGlobalRequestId) 2108configurationId = blockedRequest.BuildRequest.ConfigurationId; 2117if (executingRequest.BuildRequest.GlobalRequestId == request.ParentGlobalRequestId) 2119configurationId = executingRequest.BuildRequest.ConfigurationId; 2346if (TargetsMatch(requestTargetsSet, existingRequest.BuildRequest.Targets)) 2348request.GlobalRequestId = existingRequest.BuildRequest.GlobalRequestId; 2451int workId = useConfigurations ? buildEvent.Request.BuildRequest.ConfigurationId : buildEvent.Request.BuildRequest.GlobalRequestId; 2647useConfigurations ? request.BuildRequest.ConfigurationId : request.BuildRequest.GlobalRequestId, 2651_configCache[request.BuildRequest.ConfigurationId].ProjectFullPath, 2652String.Join(", ", request.BuildRequest.Targets)); 2783.BuildRequest.GlobalRequestId) 2978var buildRequest = request.BuildRequest;
BackEnd\Components\Scheduler\SchedulingData.cs (32)
265if (!_configurationToRequests.TryGetValue(request.BuildRequest.ConfigurationId, out requests)) 268_configurationToRequests[request.BuildRequest.ConfigurationId] = requests; 281ErrorUtilities.VerifyThrow(_buildHierarchy.ContainsKey(parent), $"Parent doesn't exist in build hierarchy for request {request.BuildRequest.GlobalRequestId}"); 297_blockedRequests.Remove(request.BuildRequest.GlobalRequestId); 301_yieldingRequests.Remove(request.BuildRequest.GlobalRequestId); 309_executingRequests.Remove(request.BuildRequest.GlobalRequestId); 314_readyRequests.Remove(request.BuildRequest.GlobalRequestId); 333ErrorUtilities.VerifyThrow(!requestsAssignedToNode.Contains(request), $"Request {request.BuildRequest.GlobalRequestId} is already scheduled to node {request.AssignedNode}"); 344if (!configurationsAssignedToNode.Contains(request.BuildRequest.ConfigurationId)) 346configurationsAssignedToNode.Add(request.BuildRequest.ConfigurationId); 357ErrorUtilities.VerifyThrow(!_blockedRequests.ContainsKey(request.BuildRequest.GlobalRequestId), $"Request with global id {request.BuildRequest.GlobalRequestId} is already blocked!"); 358_blockedRequests[request.BuildRequest.GlobalRequestId] = request; 362ErrorUtilities.VerifyThrow(!_yieldingRequests.ContainsKey(request.BuildRequest.GlobalRequestId), $"Request with global id {request.BuildRequest.GlobalRequestId} is already yielded!"); 363_yieldingRequests[request.BuildRequest.GlobalRequestId] = request; 367ErrorUtilities.VerifyThrow(_configurationToRequests.ContainsKey(request.BuildRequest.ConfigurationId), $"Configuration {request.BuildRequest.ConfigurationId} never had requests assigned to it."); 368ErrorUtilities.VerifyThrow(_configurationToRequests[request.BuildRequest.ConfigurationId].Count > 0, $"Configuration {request.BuildRequest.ConfigurationId} has no requests assigned to it."); 369_configurationToRequests[request.BuildRequest.ConfigurationId].Remove(request); 379ErrorUtilities.VerifyThrow(!_executingRequests.ContainsKey(request.BuildRequest.GlobalRequestId), $"Request with global id {request.BuildRequest.GlobalRequestId} is already executing!"); 382_executingRequests[request.BuildRequest.GlobalRequestId] = request; 384_configurationToNode[request.BuildRequest.ConfigurationId] = request.AssignedNode; 393ErrorUtilities.VerifyThrow(!_readyRequests.ContainsKey(request.BuildRequest.GlobalRequestId), $"Request with global id {request.BuildRequest.GlobalRequestId} is already ready!"); 394_readyRequests[request.BuildRequest.GlobalRequestId] = request; 402ErrorUtilities.VerifyThrow(!readyRequestsOnNode.Contains(request), $"Request with global id {request.BuildRequest.GlobalRequestId} is already marked as ready on node {request.AssignedNode}"); 407ErrorUtilities.ThrowInternalError($"Request with global id {request.BuildRequest.GlobalRequestId} cannot transition to the Unscheduled state"); 550return InternalGetScheduledRequestByGlobalRequestId(request.BuildRequest.GlobalRequestId) != null; 639return CanScheduleConfigurationToNode(request.BuildRequest.ConfigurationId, nodeId);
BackEnd\Components\Scheduler\SchedulingPlan.cs (6)
211return _configCache[rootRequest.BuildRequest.ConfigurationId].ProjectFullPath + ".buildplan"; 428if (request.BuildRequest.SubmissionId == submissionId) 442file.Write(request.BuildRequest.ConfigurationId); 445file.Write(" {0}", child.BuildRequest.ConfigurationId); 465accumulatedTimeByConfiguration.TryGetValue(request.BuildRequest.ConfigurationId, out accumulatedTime); 466accumulatedTimeByConfiguration[request.BuildRequest.ConfigurationId] = accumulatedTime + request.GetTimeSpentInState(SchedulableRequestState.Executing).TotalMilliseconds;