Beispiel #1
0
        public RateLimitingSamplingStrategy DeepCopy()
        {
            var tmp2 = new RateLimitingSamplingStrategy();

            tmp2.MaxTracesPerSecond = this.MaxTracesPerSecond;
            return(tmp2);
        }
Beispiel #2
0
        public void JaegerThriftRateLimitingSamplingStrategy_FromThrift()
        {
            var strat = new JaegerThriftRateLimitingSamplingStrategy(5);

            var from = strat.FromThrift();

            Assert.Equal(strat.MaxTracesPerSecond, from.MaxTracesPerSecond);
        }
        public async Task ReadAsync(TProtocol iprot, CancellationToken cancellationToken)
        {
            iprot.IncrementRecursionDepth();
            try
            {
                bool   isset_strategyType = false;
                TField field;
                await iprot.ReadStructBeginAsync(cancellationToken);

                while (true)
                {
                    field = await iprot.ReadFieldBeginAsync(cancellationToken);

                    if (field.Type == TType.Stop)
                    {
                        break;
                    }

                    switch (field.ID)
                    {
                    case 1:
                        if (field.Type == TType.I32)
                        {
                            StrategyType = (SamplingStrategyType)await iprot.ReadI32Async(cancellationToken);

                            isset_strategyType = true;
                        }
                        else
                        {
                            await TProtocolUtil.SkipAsync(iprot, field.Type, cancellationToken);
                        }
                        break;

                    case 2:
                        if (field.Type == TType.Struct)
                        {
                            ProbabilisticSampling = new ProbabilisticSamplingStrategy();
                            await ProbabilisticSampling.ReadAsync(iprot, cancellationToken);
                        }
                        else
                        {
                            await TProtocolUtil.SkipAsync(iprot, field.Type, cancellationToken);
                        }
                        break;

                    case 3:
                        if (field.Type == TType.Struct)
                        {
                            RateLimitingSampling = new RateLimitingSamplingStrategy();
                            await RateLimitingSampling.ReadAsync(iprot, cancellationToken);
                        }
                        else
                        {
                            await TProtocolUtil.SkipAsync(iprot, field.Type, cancellationToken);
                        }
                        break;

                    case 4:
                        if (field.Type == TType.Struct)
                        {
                            OperationSampling = new PerOperationSamplingStrategies();
                            await OperationSampling.ReadAsync(iprot, cancellationToken);
                        }
                        else
                        {
                            await TProtocolUtil.SkipAsync(iprot, field.Type, cancellationToken);
                        }
                        break;

                    default:
                        await TProtocolUtil.SkipAsync(iprot, field.Type, cancellationToken);

                        break;
                    }

                    await iprot.ReadFieldEndAsync(cancellationToken);
                }

                await iprot.ReadStructEndAsync(cancellationToken);

                if (!isset_strategyType)
                {
                    throw new TProtocolException(TProtocolException.INVALID_DATA);
                }
            }
            finally
            {
                iprot.DecrementRecursionDepth();
            }
        }