/// <inheritdoc/> protected override void ProcessRecordInternal() { var monitoringPolicyDescription = new MonitoringPolicyDescription( failureAction: this.FailureAction, healthCheckWaitDurationInMilliseconds: this.HealthCheckWaitDurationInMilliseconds, healthCheckStableDurationInMilliseconds: this.HealthCheckStableDurationInMilliseconds, healthCheckRetryTimeoutInMilliseconds: this.HealthCheckRetryTimeoutInMilliseconds, upgradeTimeoutInMilliseconds: this.UpgradeTimeoutInMilliseconds, upgradeDomainTimeoutInMilliseconds: this.UpgradeDomainTimeoutInMilliseconds); var clusterHealthPolicy = new ClusterHealthPolicy( considerWarningAsError: this.ConsiderWarningAsError, maxPercentUnhealthyNodes: this.MaxPercentUnhealthyNodes, maxPercentUnhealthyApplications: this.MaxPercentUnhealthyApplications, applicationTypeHealthPolicyMap: this.ApplicationTypeHealthPolicyMap, nodeTypeHealthPolicyMap: this.NodeTypeHealthPolicyMap); var clusterUpgradeHealthPolicyObject = new ClusterUpgradeHealthPolicyObject( maxPercentDeltaUnhealthyNodes: this.MaxPercentDeltaUnhealthyNodes, maxPercentUpgradeDomainDeltaUnhealthyNodes: this.MaxPercentUpgradeDomainDeltaUnhealthyNodes); var applicationHealthPolicies = new ApplicationHealthPolicies( applicationHealthPolicyMap: this.ApplicationHealthPolicyMap); var startClusterUpgradeDescription = new StartClusterUpgradeDescription( codeVersion: this.CodeVersion, configVersion: this.ConfigVersion, upgradeKind: this.UpgradeKind, rollingUpgradeMode: this.RollingUpgradeMode, upgradeReplicaSetCheckTimeoutInSeconds: this.UpgradeReplicaSetCheckTimeoutInSeconds, forceRestart: this.ForceRestart, sortOrder: this.SortOrder, monitoringPolicy: monitoringPolicyDescription, clusterHealthPolicy: clusterHealthPolicy, enableDeltaHealthEvaluation: this.EnableDeltaHealthEvaluation, clusterUpgradeHealthPolicy: clusterUpgradeHealthPolicyObject, applicationHealthPolicyMap: applicationHealthPolicies, instanceCloseDelayDurationInSeconds: this.InstanceCloseDelayDurationInSeconds); var result = this.ServiceFabricClient.Cluster.ValidateClusterUpgradeAsync( startClusterUpgradeDescription: startClusterUpgradeDescription, serverTimeout: this.ServerTimeout, cancellationToken: this.CancellationToken).GetAwaiter().GetResult(); if (result != null) { this.WriteObject(this.FormatOutput(result)); } }
/// <summary> /// Serializes the object to JSON. /// </summary> /// <param name="writer">The <see cref="T: Newtonsoft.Json.JsonWriter" /> to write to.</param> /// <param name="obj">The object to serialize to JSON.</param> internal static void Serialize(JsonWriter writer, ClusterUpgradeHealthPolicyObject obj) { // Required properties are always serialized, optional properties are serialized when not null. writer.WriteStartObject(); if (obj.MaxPercentDeltaUnhealthyNodes != null) { writer.WriteProperty(obj.MaxPercentDeltaUnhealthyNodes, "MaxPercentDeltaUnhealthyNodes", JsonWriterExtensions.WriteIntValue); } if (obj.MaxPercentUpgradeDomainDeltaUnhealthyNodes != null) { writer.WriteProperty(obj.MaxPercentUpgradeDomainDeltaUnhealthyNodes, "MaxPercentUpgradeDomainDeltaUnhealthyNodes", JsonWriterExtensions.WriteIntValue); } writer.WriteEndObject(); }
/// <inheritdoc/> protected override void ProcessRecordInternal() { var rollingUpgradeUpdateDescription = new RollingUpgradeUpdateDescription( rollingUpgradeMode: this.RollingUpgradeMode, forceRestart: this.ForceRestart, replicaSetCheckTimeoutInMilliseconds: this.ReplicaSetCheckTimeoutInMilliseconds, failureAction: this.FailureAction, healthCheckWaitDurationInMilliseconds: this.HealthCheckWaitDurationInMilliseconds, healthCheckStableDurationInMilliseconds: this.HealthCheckStableDurationInMilliseconds, healthCheckRetryTimeoutInMilliseconds: this.HealthCheckRetryTimeoutInMilliseconds, upgradeTimeoutInMilliseconds: this.UpgradeTimeoutInMilliseconds, upgradeDomainTimeoutInMilliseconds: this.UpgradeDomainTimeoutInMilliseconds, instanceCloseDelayDurationInSeconds: this.InstanceCloseDelayDurationInSeconds); var clusterHealthPolicy = new ClusterHealthPolicy( considerWarningAsError: this.ConsiderWarningAsError, maxPercentUnhealthyNodes: this.MaxPercentUnhealthyNodes, maxPercentUnhealthyApplications: this.MaxPercentUnhealthyApplications, applicationTypeHealthPolicyMap: this.ApplicationTypeHealthPolicyMap, nodeTypeHealthPolicyMap: this.NodeTypeHealthPolicyMap); var clusterUpgradeHealthPolicyObject = new ClusterUpgradeHealthPolicyObject( maxPercentDeltaUnhealthyNodes: this.MaxPercentDeltaUnhealthyNodes, maxPercentUpgradeDomainDeltaUnhealthyNodes: this.MaxPercentUpgradeDomainDeltaUnhealthyNodes); var applicationHealthPolicies = new ApplicationHealthPolicies( applicationHealthPolicyMap: this.ApplicationHealthPolicyMap); var updateClusterUpgradeDescription = new UpdateClusterUpgradeDescription( upgradeKind: this.UpgradeKind, updateDescription: rollingUpgradeUpdateDescription, clusterHealthPolicy: clusterHealthPolicy, enableDeltaHealthEvaluation: this.EnableDeltaHealthEvaluation, clusterUpgradeHealthPolicy: clusterUpgradeHealthPolicyObject, applicationHealthPolicyMap: applicationHealthPolicies); this.ServiceFabricClient.Cluster.UpdateClusterUpgradeAsync( updateClusterUpgradeDescription: updateClusterUpgradeDescription, serverTimeout: this.ServerTimeout, cancellationToken: this.CancellationToken).GetAwaiter().GetResult(); Console.WriteLine("Success!"); }