blob: a21f23552455b7e32c0dbdc5a60e3ced5ab35b6a [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.cassandra.config;
import org.junit.BeforeClass;
import org.junit.Test;
import static org.apache.cassandra.config.DataStorageSpec.DataStorageUnit.MEBIBYTES;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNull;
public class ParseAndConvertUnitsTest
{
@BeforeClass
public static void setupDatabaseDescriptor()
{
DatabaseDescriptor.daemonInitialization();
}
// CASSANDRA-15234
@Test
public void testConfigurationLoaderParser()
{
Config config = DatabaseDescriptor.loadConfig();
//Confirm duration parameters were successfully parsed with the default values in cassandra.yaml
assertEquals(new DurationSpec.IntMillisecondsBound(10800000), config.max_hint_window);
assertEquals(new DurationSpec.LongMillisecondsBound(0), config.native_transport_idle_timeout);
assertEquals(new DurationSpec.LongMillisecondsBound(10000), config.request_timeout);
assertEquals(new DurationSpec.LongMillisecondsBound(5000), config.read_request_timeout);
assertEquals(new DurationSpec.LongMillisecondsBound(10000), config.range_request_timeout);
assertEquals(new DurationSpec.LongMillisecondsBound(2000), config.write_request_timeout);
assertEquals(new DurationSpec.LongMillisecondsBound(5000), config.counter_write_request_timeout);
assertEquals(new DurationSpec.LongMillisecondsBound(1800), config.cas_contention_timeout);
assertEquals(new DurationSpec.LongMillisecondsBound(60000), config.truncate_request_timeout);
assertEquals(new DurationSpec.IntSecondsBound(300), config.streaming_keep_alive_period);
assertEquals(new DurationSpec.LongMillisecondsBound(500), config.slow_query_log_timeout);
assertEquals(new DurationSpec.IntMillisecondsBound(2000), config.internode_tcp_connect_timeout);
assertEquals(new DurationSpec.IntMillisecondsBound(30000), config.internode_tcp_user_timeout);
assertEquals(new DurationSpec.IntMillisecondsBound(0), config.commitlog_sync_group_window);
assertEquals(new DurationSpec.IntMillisecondsBound(0), config.commitlog_sync_period);
assertNull(config.periodic_commitlog_sync_lag_block);
assertEquals(new DurationSpec.IntMillisecondsBound(250), config.cdc_free_space_check_interval);
assertEquals(new DurationSpec.IntMillisecondsBound(100), config.dynamic_snitch_update_interval);
assertEquals(new DurationSpec.IntMillisecondsBound(600000), config.dynamic_snitch_reset_interval);
assertEquals(new DurationSpec.IntMillisecondsBound(200), config.gc_log_threshold);
assertEquals(new DurationSpec.IntMillisecondsBound(10000), config.hints_flush_period);
assertEquals(new DurationSpec.IntMillisecondsBound(1000), config.gc_warn_threshold);
assertEquals(new DurationSpec.IntSecondsBound(86400), config.trace_type_query_ttl);
assertEquals(new DurationSpec.IntSecondsBound(604800), config.trace_type_repair_ttl);
assertEquals(new DurationSpec.IntMillisecondsBound(2000), config.permissions_validity);
assertNull(config.permissions_update_interval);
assertEquals(new DurationSpec.IntMillisecondsBound(2000), config.roles_validity);
assertNull(config.roles_update_interval);
assertEquals(new DurationSpec.IntMillisecondsBound(2000), config.credentials_validity);
assertNull(config.credentials_update_interval);
assertEquals(new DurationSpec.IntMinutesBound(60), config.index_summary_resize_interval);
assertEquals(DurationSpec.IntSecondsBound.inSecondsString("4h"), config.key_cache_save_period);
assertEquals(new DurationSpec.IntSecondsBound(30), config.cache_load_timeout);
assertEquals(new DurationSpec.LongMillisecondsBound(1500), config.user_defined_functions_fail_timeout);
assertEquals(new DurationSpec.LongMillisecondsBound(500), config.user_defined_functions_warn_timeout);
assertEquals(new DurationSpec.IntSecondsBound(3600), config.validation_preview_purge_head_start);
//Confirm space parameters were successfully parsed with the default values in cassandra.yaml
assertNull(config.memtable_heap_space);
assertNull(config.memtable_offheap_space);
assertNull(config.repair_session_space); //null everywhere so should be correct, let's check whether it will bomb
assertEquals(new DataStorageSpec.IntBytesBound(4194304), config.internode_application_send_queue_capacity);
assertEquals(new DataStorageSpec.IntBytesBound(134217728), config.internode_application_send_queue_reserve_endpoint_capacity);
assertEquals(new DataStorageSpec.IntBytesBound(536870912), config.internode_application_send_queue_reserve_global_capacity);
assertEquals(new DataStorageSpec.IntBytesBound(4194304), config.internode_application_receive_queue_capacity);
assertEquals(new DataStorageSpec.IntBytesBound(134217728), config.internode_application_receive_queue_reserve_endpoint_capacity);
assertEquals(new DataStorageSpec.IntBytesBound(536870912), config.internode_application_receive_queue_reserve_global_capacity);
assertEquals(new DataStorageSpec.IntMebibytesBound(16), config.native_transport_max_frame_size);
assertEquals(new DataStorageSpec.IntMebibytesBound(256), config.max_value_size);
assertEquals(new DataStorageSpec.IntKibibytesBound(4), config.column_index_size);
assertEquals(new DataStorageSpec.IntKibibytesBound(2), config.column_index_cache_size);
assertEquals(new DataStorageSpec.IntKibibytesBound(5), config.batch_size_warn_threshold);
assertEquals(new DataStorageSpec.IntKibibytesBound(50), config.batch_size_fail_threshold);
assertEquals(new DataStorageSpec.IntMebibytesBound(100), config.compaction_large_partition_warning_threshold);
assertNull(config.commitlog_total_space);
assertEquals(new DataStorageSpec.IntMebibytesBound(5), config.commitlog_segment_size);
assertNull(config.max_mutation_size); //not set explicitly in the default yaml, check the config; not set there too
assertEquals(new DataStorageSpec.IntMebibytesBound(0), config.cdc_total_space);
assertEquals(new DataStorageSpec.IntKibibytesBound(1024), config.hinted_handoff_throttle);
assertEquals(new DataStorageSpec.IntKibibytesBound(1024), config.batchlog_replay_throttle);
assertEquals(new DataStorageSpec.IntKibibytesBound(10240), config.trickle_fsync_interval);
assertEquals(new DataStorageSpec.IntMebibytesBound(50), config.sstable_preemptive_open_interval);
assertNull(config.counter_cache_size);
assertNull(config.file_cache_size);
assertNull(config.index_summary_capacity);
assertEquals(new DataStorageSpec.LongMebibytesBound(1), config.prepared_statements_cache_size);
assertNull(config.key_cache_size);
assertEquals(new DataStorageSpec.LongMebibytesBound(16), config.row_cache_size);
assertNull(config.native_transport_max_request_data_in_flight);
assertNull(config.native_transport_max_request_data_in_flight_per_ip);
assertEquals(new DataStorageSpec.IntBytesBound(1, MEBIBYTES), config.native_transport_receive_queue_capacity);
//Confirm rate parameters were successfully parsed with the default values in cassandra.yaml
assertEquals(new DataRateSpec.LongBytesPerSecondBound(0), config.compaction_throughput);
assertEquals(new DataRateSpec.LongBytesPerSecondBound(23841858, DataRateSpec.DataRateUnit.MEBIBYTES_PER_SECOND), config.stream_throughput_outbound);
assertEquals(new DataRateSpec.LongBytesPerSecondBound(24, DataRateSpec.DataRateUnit.MEBIBYTES_PER_SECOND), config.inter_dc_stream_throughput_outbound);
}
}