Beispiel #1
0
        protected override void ProcessRecord()
        {
            var clusterConnection = this.GetClusterConnection();

            try
            {
                var queryDescription = new NodeHealthQueryDescription(this.NodeName);
                if (this.ConsiderWarningAsError.HasValue || this.MaxPercentUnhealthyNodes.HasValue)
                {
                    queryDescription.HealthPolicy = new ClusterHealthPolicy()
                    {
                        ConsiderWarningAsError   = this.ConsiderWarningAsError.GetValueOrDefault(),
                        MaxPercentUnhealthyNodes = this.MaxPercentUnhealthyNodes.GetValueOrDefault()
                    };
                }

                if (this.EventsHealthStateFilter.HasValue)
                {
                    this.WriteWarning(StringResources.PowerShell_EventsHealthStateFilter_Deprecated);
                    if (!this.EventsFilter.HasValue)
                    {
                        this.EventsFilter = (HealthStateFilter)this.EventsHealthStateFilter;
                    }
                }

                if (this.EventsFilter.HasValue)
                {
                    queryDescription.EventsFilter = new HealthEventsFilter()
                    {
                        HealthStateFilterValue = this.EventsFilter.Value,
                    };
                }

                var nodeHealth = clusterConnection.GetNodeHealthAsync(
                    queryDescription,
                    this.GetTimeout(),
                    this.GetCancellationToken()).Result;
                this.WriteObject(this.FormatOutput(nodeHealth));
            }
            catch (AggregateException aggregateException)
            {
                aggregateException.Handle((ae) =>
                {
                    this.ThrowTerminatingError(
                        ae,
                        Constants.GetNodeHealthErrorId,
                        clusterConnection);
                    return(true);
                });
            }
        }
Beispiel #2
0
 public GetNodeHealthRequest(IFabricClient fabricClient, NodeHealthQueryDescription queryDescription, TimeSpan timeout)
     : base(fabricClient, timeout)
 {
     ThrowIf.Null(queryDescription, "queryDescription");
     this.QueryDescription = queryDescription;
 }