DBIx-Custom / t / next / common-sqlserver.t /
e038c37 12 years ago
1 contributor
428 lines | 13.31kb
use strict;
use warnings;

use FindBin;
use lib "$FindBin::Bin/common";
$ENV{DBIX_CUSTOM_TEST_RUN} = 1
  if -f "$FindBin::Bin/run/common-sqlserver.run";
$ENV{DBIX_CUSTOM_SKIP_MESSAGE} = 'sqlserver private test';

use DBIx::Custom::Next;
{
    package DBIx::Custom::Next;
    no warnings 'redefine';

    my $table1 = 'table1';
    my $table2 = 'table2';
    my $table2_alias = 'table2_alias';
    my $table3 = 'table3';
    my $key1 = 'key1';
    my $key2 = 'key2';
    my $key3 = 'key3';
    my $key4 = 'key4';
    my $key5 = 'key5';
    my $key6 = 'key6';
    my $key7 = 'key7';
    my $key8 = 'key8';
    my $key9 = 'key9';
    my $key10 = 'key10';
    
    has table1 => $table1;
    has table2 => $table2;
    has table2_alias => $table2_alias;
    has table3 => $table3;
    has key1 => $key1;
    has key2 => $key2;
    has key3 => $key3;
    has key4 => $key4;
    has key5 => $key5;
    has key6 => $key6;
    has key7 => $key7;
    has key8 => $key8;
    has key9 => $key9;
    has key10 => $key10;

    my $date_typename = 'date';
    my $datetime_typename = 'datetime';

    sub date_typename { lc $date_typename }
    sub datetime_typename { lc $datetime_typename }

    my $date_datatype = -9;
    my $datetime_datatype = 93;

    sub date_datatype { lc $date_datatype }
    sub datetime_datatype { lc $datetime_datatype }

    has exclude_table => sub {
        return qr/^(
          CHECK_CONSTRAINTS
          |COLUMN_DOMAIN_USAGE
          |COLUMN_PRIVILEGES
          |COLUMNS
          |CONSTRAINT_COLUMN_USAGE
          |CONSTRAINT_TABLE_USAGE
          |DOMAIN_CONSTRAINTS
          |DOMAINS
          |KEY_COLUMN_USAGE
          |PARAMETERS
          |REFERENTIAL_CONSTRAINTS
          |ROUTINE_COLUMNS
          |ROUTINES
          |SCHEMATA
          |TABLE_CONSTRAINTS
          |TABLE_PRIVILEGES
          |TABLES
          |VIEW_COLUMN_USAGE
          |VIEW_TABLE_USAGE
          |VIEWS
          |all_columns
          |all_objects
          |all_parameters
          |all_sql_modules
          |all_views
          |allocation_units
          |assemblies
          |assembly_files
          |assembly_modules
          |assembly_references
          |assembly_types
          |asymmetric_keys
          |backup_devices
          |certificates
          |change_tracking_databases
          |change_tracking_tables
          |check_constraints
          |column_type_usages
          |column_xml_schema_collection_usages
          |columns
          |computed_columns
          |configurations
          |conversation_endpoints
          |conversation_groups
          |conversation_priorities
          |credentials
          |crypt_properties
          |cryptographic_providers
          |data_spaces
          |database_audit_specification_details
          |database_audit_specifications
          |database_files
          |database_mirroring
          |database_mirroring_endpoints
          |database_permissions
          |database_principal_aliases
          |database_principals
          |database_recovery_status
          |database_role_members
          |databases
          |default_constraints
          |destination_data_spaces
          |dm_audit_actions
          |dm_audit_class_type_map
          |dm_broker_activated_tasks
          |dm_broker_connections
          |dm_broker_forwarded_messages
          |dm_broker_queue_monitors
          |dm_cdc_errors
          |dm_cdc_log_scan_sessions
          |dm_clr_appdomains
          |dm_clr_loaded_assemblies
          |dm_clr_properties
          |dm_clr_tasks
          |dm_cryptographic_provider_properties
          |dm_database_encryption_keys
          |dm_db_file_space_usage
          |dm_db_index_usage_stats
          |dm_db_mirroring_auto_page_repair
          |dm_db_mirroring_connections
          |dm_db_mirroring_past_actions
          |dm_db_missing_index_details
          |dm_db_missing_index_group_stats
          |dm_db_missing_index_groups
          |dm_db_partition_stats
          |dm_db_persisted_sku_features
          |dm_db_script_level
          |dm_db_session_space_usage
          |dm_db_task_space_usage
          |dm_exec_background_job_queue
          |dm_exec_background_job_queue_stats
          |dm_exec_cached_plans
          |dm_exec_connections
          |dm_exec_procedure_stats
          |dm_exec_query_memory_grants
          |dm_exec_query_optimizer_info
          |dm_exec_query_resource_semaphores
          |dm_exec_query_stats
          |dm_exec_query_transformation_stats
          |dm_exec_requests
          |dm_exec_sessions
          |dm_exec_trigger_stats
          |dm_filestream_file_io_handles
          |dm_filestream_file_io_requests
          |dm_fts_active_catalogs
          |dm_fts_fdhosts
          |dm_fts_index_population
          |dm_fts_memory_buffers
          |dm_fts_memory_pools
          |dm_fts_outstanding_batches
          |dm_fts_population_ranges
          |dm_io_backup_tapes
          |dm_io_cluster_shared_drives
          |dm_io_pending_io_requests
          |dm_os_buffer_descriptors
          |dm_os_child_instances
          |dm_os_cluster_nodes
          |dm_os_dispatcher_pools
          |dm_os_dispatchers
          |dm_os_hosts
          |dm_os_latch_stats
          |dm_os_loaded_modules
          |dm_os_memory_allocations
          |dm_os_memory_brokers
          |dm_os_memory_cache_clock_hands
          |dm_os_memory_cache_counters
          |dm_os_memory_cache_entries
          |dm_os_memory_cache_hash_tables
          |dm_os_memory_clerks
          |dm_os_memory_node_access_stats
          |dm_os_memory_nodes
          |dm_os_memory_objects
          |dm_os_memory_pools
          |dm_os_nodes
          |dm_os_performance_counters
          |dm_os_process_memory
          |dm_os_ring_buffers
          |dm_os_schedulers
          |dm_os_spinlock_stats
          |dm_os_stacks
          |dm_os_sublatches
          |dm_os_sys_info
          |dm_os_sys_memory
          |dm_os_tasks
          |dm_os_threads
          |dm_os_virtual_address_dump
          |dm_os_wait_stats
          |dm_os_waiting_tasks
          |dm_os_worker_local_storage
          |dm_os_workers
          |dm_qn_subscriptions
          |dm_repl_articles
          |dm_repl_schemas
          |dm_repl_tranhash
          |dm_repl_traninfo
          |dm_resource_governor_configuration
          |dm_resource_governor_resource_pools
          |dm_resource_governor_workload_groups
          |dm_server_audit_status
          |dm_tran_active_snapshot_database_transactions
          |dm_tran_active_transactions
          |dm_tran_commit_table
          |dm_tran_current_snapshot
          |dm_tran_current_transaction
          |dm_tran_database_transactions
          |dm_tran_locks
          |dm_tran_session_transactions
          |dm_tran_top_version_generators
          |dm_tran_transactions_snapshot
          |dm_tran_version_store
          |dm_xe_map_values
          |dm_xe_object_columns
          |dm_xe_objects
          |dm_xe_packages
          |dm_xe_session_event_actions
          |dm_xe_session_events
          |dm_xe_session_object_columns
          |dm_xe_session_targets
          |dm_xe_sessions
          |endpoint_webmethods
          |endpoints
          |event_notification_event_types
          |event_notifications
          |events
          |extended_procedures
          |extended_properties
          |filegroups
          |foreign_key_columns
          |foreign_keys
          |fulltext_catalogs
          |fulltext_document_types
          |fulltext_index_catalog_usages
          |fulltext_index_columns
          |fulltext_index_fragments
          |fulltext_indexes
          |fulltext_languages
          |fulltext_stoplists
          |fulltext_stopwords
          |fulltext_system_stopwords
          |function_order_columns
          |http_endpoints
          |identity_columns
          |index_columns
          |indexes
          |internal_tables
          |key_constraints
          |key_encryptions
          |linked_logins
          |login_token
          |master_files
          |master_key_passwords
          |message_type_xml_schema_collection_usages
          |messages
          |module_assembly_usages
          |numbered_procedure_parameters
          |numbered_procedures
          |objects
          |openkeys
          |parameter_type_usages
          |parameter_xml_schema_collection_usages
          |parameters
          |partition_functions
          |partition_parameters
          |partition_range_values
          |partition_schemes
          |partitions
          |plan_guides
          |procedures
          |remote_logins
          |remote_service_bindings
          |resource_governor_configuration
          |resource_governor_resource_pools
          |resource_governor_workload_groups
          |routes
          |schemas
          |securable_classes
          |server_assembly_modules
          |server_audit_specification_details
          |server_audit_specifications
          |server_audits
          |server_event_notifications
          |server_event_session_actions
          |server_event_session_events
          |server_event_session_fields
          |server_event_session_targets
          |server_event_sessions
          |server_events
          |server_file_audits
          |server_permissions
          |server_principal_credentials
          |server_principals
          |server_role_members
          |server_sql_modules
          |server_trigger_events
          |server_triggers
          |servers
          |service_broker_endpoints
          |service_contract_message_usages
          |service_contract_usages
          |service_contracts
          |service_message_types
          |service_queue_usages
          |service_queues
          |services
          |soap_endpoints
          |spatial_index_tessellations
          |spatial_indexes
          |spatial_reference_systems
          |sql_dependencies
          |sql_logins
          |sql_modules
          |stats
          |stats_columns
          |symmetric_keys
          |synonyms
          |syscacheobjects
          |syscharsets
          |syscolumns
          |syscomments
          |sysconfigures
          |sysconstraints
          |syscurconfigs
          |syscursorcolumns
          |syscursorrefs
          |syscursors
          |syscursortables
          |sysdatabases
          |sysdepends
          |sysdevices
          |sysfilegroups
          |sysfiles
          |sysforeignkeys
          |sysfulltextcatalogs
          |sysindexes
          |sysindexkeys
          |syslanguages
          |syslockinfo
          |syslogins
          |sysmembers
          |sysmessages
          |sysobjects
          |sysoledbusers
          |sysopentapes
          |sysperfinfo
          |syspermissions
          |sysprocesses
          |sysprotects
          |sysreferences
          |sysremotelogins
          |sysservers
          |system_columns
          |system_components_surface_area_configuration
          |system_objects
          |system_parameters
          |system_sql_modules
          |system_views
          |systypes
          |sysusers
          |table_types
          |tables
          |tcp_endpoints
          |trace_categories
          |trace_columns
          |trace_event_bindings
          |trace_events
          |trace_subclass_values
          |traces
          |transmission_queue
          |trigger_event_types
          |trigger_events
          |triggers
          |type_assembly_usages
          |types
          |user_token
          |via_endpoints
          |views
          |xml_indexes
          |xml_schema_attributes
          |xml_schema_collections
          |xml_schema_component_placements
          |xml_schema_components
          |xml_schema_elements
          |xml_schema_facets
          |xml_schema_model_groups
          |xml_schema_namespaces
          |xml_schema_types
          |xml_schema_wildcard_namespaces
          |xml_schema_wildcards
        )/x
    };

    my $dsn = "dbi:ODBC:driver={SQL Server};Server={localhost\\SQLEXPRESS};"
      . "Trusted_Connection=No;AutoTranslate=No;Database=dbix_custom;";
    has dsn => $dsn;
    has user  => 'dbix_custom';
    has password => 'dbix_custom';
    
    sub create_table1 { "create table $table1 ($key1 varchar(255), $key2 varchar(255))" }
    sub create_table1_2 {"create table $table1 ($key1 varchar(255), $key2 varchar(255), "
     . "$key3 varchar(255), $key4 varchar(255), $key5 varchar(255))" }
    sub create_table1_type { "create table $table1 ($key1 $date_typename, $key2 $datetime_typename)" }
    sub create_table1_highperformance { "create table $table1 ($key1 varchar(255), $key2 varchar(255), "
      . "$key3 varchar(255), $key4 varchar(255), $key5 varchar(255), $key6 varchar(255), $key7 varchar(255))" }
    sub create_table2 { "create table $table2 ($key1 varchar(255), $key3 varchar(255))" }
    sub create_table2_2 { "create table $table2 ($key1 varchar(255), $key2 varchar(255), $key3 varchar(255))" }
    sub create_table3 { "create table $table3 ($key1 varchar(255), $key2 varchar(255), $key3 varchar(255))" }
    sub create_table_reserved { 'create table "table" ("select" varchar(255), "update" varchar(255))' }
}

require "$FindBin::Bin/common.t";