nautobot 2.0.0a2__py3-none-any.whl → 2.0.0b1__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- nautobot/__init__.py +1 -5
- nautobot/apps/api.py +6 -8
- nautobot/apps/forms.py +0 -2
- nautobot/apps/ui.py +0 -8
- nautobot/circuits/api/serializers.py +9 -119
- nautobot/circuits/api/urls.py +1 -1
- nautobot/circuits/api/views.py +0 -1
- nautobot/circuits/choices.py +0 -2
- nautobot/circuits/filters.py +7 -6
- nautobot/circuits/forms.py +3 -73
- nautobot/circuits/migrations/0001_initial_part_1.py +0 -1
- nautobot/circuits/migrations/0002_initial_part_2.py +0 -1
- nautobot/circuits/migrations/0003_auto_slug.py +0 -1
- nautobot/circuits/migrations/0004_increase_provider_account_length.py +0 -1
- nautobot/circuits/migrations/0005_providernetwork.py +0 -1
- nautobot/circuits/migrations/0006_cache_circuit_terminations.py +0 -1
- nautobot/circuits/migrations/0007_circuitterminations_primary_model.py +0 -1
- nautobot/circuits/migrations/0008_add_natural_indexing.py +0 -1
- nautobot/circuits/migrations/0009_circuittermination_location.py +0 -1
- nautobot/circuits/migrations/0010_rename_foreign_keys_and_related_names.py +0 -1
- nautobot/circuits/migrations/0011_remove_site_foreign_key_from_circuit_termination_class.py +0 -1
- nautobot/circuits/migrations/0012_created_datetime.py +0 -1
- nautobot/circuits/migrations/0013_alter_circuittermination__path.py +0 -1
- nautobot/circuits/migrations/0014_related_name_changes.py +1 -2
- nautobot/circuits/migrations/0015_remove_circuittype_provider_slug.py +20 -0
- nautobot/circuits/migrations/0016_tagsfield.py +34 -0
- nautobot/circuits/migrations/0017_fixup_null_statuses.py +22 -0
- nautobot/circuits/migrations/0018_status_nonnullable.py +22 -0
- nautobot/circuits/models.py +3 -93
- nautobot/circuits/navigation.py +14 -69
- nautobot/circuits/signals.py +0 -2
- nautobot/circuits/tables.py +42 -5
- nautobot/circuits/templates/circuits/circuit_retrieve.html +1 -1
- nautobot/circuits/templates/circuits/circuittermination_retrieve.html +1 -1
- nautobot/circuits/templates/circuits/circuittype_retrieve.html +1 -1
- nautobot/circuits/templates/circuits/provider_create.html +0 -1
- nautobot/circuits/templates/circuits/provider_retrieve.html +1 -1
- nautobot/circuits/tests/integration/test_relationships.py +13 -16
- nautobot/circuits/tests/test_api.py +13 -43
- nautobot/circuits/tests/test_filters.py +20 -15
- nautobot/circuits/tests/test_models.py +7 -3
- nautobot/circuits/tests/test_views.py +57 -67
- nautobot/circuits/views.py +18 -9
- nautobot/core/api/__init__.py +8 -2
- nautobot/core/api/authentication.py +0 -3
- nautobot/core/api/fields.py +15 -6
- nautobot/core/api/filter_backends.py +3 -2
- nautobot/core/api/metadata.py +237 -30
- nautobot/core/api/mixins.py +94 -0
- nautobot/core/api/pagination.py +3 -3
- nautobot/core/api/parsers.py +154 -0
- nautobot/core/api/renderers.py +153 -2
- nautobot/core/api/schema.py +47 -3
- nautobot/core/api/serializers.py +377 -37
- nautobot/core/api/urls.py +11 -3
- nautobot/core/api/utils.py +174 -2
- nautobot/core/api/versioning.py +32 -10
- nautobot/core/api/views.py +266 -75
- nautobot/core/apps/__init__.py +138 -221
- nautobot/core/celery/__init__.py +112 -41
- nautobot/core/celery/backends.py +19 -13
- nautobot/core/celery/control.py +46 -0
- nautobot/core/celery/encoders.py +53 -0
- nautobot/core/celery/log.py +38 -0
- nautobot/core/celery/schedulers.py +23 -4
- nautobot/core/celery/task.py +1 -16
- nautobot/core/checks.py +0 -27
- nautobot/core/choices.py +21 -113
- nautobot/core/{cli.py → cli/__init__.py} +1 -2
- nautobot/core/cli/__main__.py +3 -0
- nautobot/core/constants.py +25 -43
- nautobot/core/context_processors.py +12 -0
- nautobot/core/filters.py +2 -2
- nautobot/core/forms/__init__.py +0 -4
- nautobot/core/forms/fields.py +39 -68
- nautobot/core/forms/forms.py +27 -27
- nautobot/core/forms/utils.py +7 -59
- nautobot/core/forms/widgets.py +0 -1
- nautobot/core/graphql/__init__.py +2 -2
- nautobot/core/graphql/schema.py +4 -27
- nautobot/core/jobs/__init__.py +75 -0
- nautobot/core/management/commands/build_ui.py +255 -0
- nautobot/core/management/commands/celery.py +0 -1
- nautobot/core/management/commands/generate_test_data.py +18 -13
- nautobot/core/management/commands/post_upgrade.py +24 -24
- nautobot/core/management/commands/validate_models.py +0 -1
- nautobot/core/middleware.py +0 -1
- nautobot/core/models/__init__.py +26 -1
- nautobot/core/models/fields.py +24 -5
- nautobot/core/models/generics.py +2 -46
- nautobot/core/models/managers.py +5 -0
- nautobot/core/models/name_color_content_types.py +1 -19
- nautobot/core/models/tree_queries.py +14 -4
- nautobot/core/models/utils.py +9 -10
- nautobot/core/models/validators.py +17 -8
- nautobot/core/releases.py +8 -10
- nautobot/core/settings.py +81 -53
- nautobot/core/tables.py +5 -5
- nautobot/core/tasks.py +4 -7
- nautobot/core/templates/base.html +1 -49
- nautobot/core/templates/base_django.html +49 -0
- nautobot/core/templates/base_react.html +55 -0
- nautobot/core/templates/buttons/export.html +6 -4
- nautobot/core/templates/generic/object_bulk_create.html +10 -21
- nautobot/core/templates/generic/object_list.html +4 -1
- nautobot/core/templates/generic/object_retrieve_plugin_full_width.html +3 -0
- nautobot/core/templates/inc/footer.html +1 -0
- nautobot/core/templates/inc/javascript.html +0 -14
- nautobot/core/templates/inc/nav_menu.html +28 -33
- nautobot/core/templates/inc/object_details_advanced_panel.html +13 -0
- nautobot/core/templates/inc/relationships_table_rows.html +2 -2
- nautobot/core/templates/nautobot_config.py.j2 +8 -25
- nautobot/core/templates/plugin_template/__init__.py-tpl +1 -2
- nautobot/core/templates/rest_framework/api.html +8 -0
- nautobot/core/templatetags/buttons.py +32 -29
- nautobot/core/templatetags/helpers.py +1 -1
- nautobot/core/testing/__init__.py +47 -44
- nautobot/core/testing/api.py +365 -47
- nautobot/core/testing/filters.py +12 -7
- nautobot/core/testing/integration.py +1 -1
- nautobot/core/testing/migrations.py +2 -0
- nautobot/core/testing/mixins.py +22 -12
- nautobot/core/testing/schema.py +2 -1
- nautobot/core/testing/views.py +28 -51
- nautobot/core/tests/integration/test_filters.py +17 -8
- nautobot/core/tests/integration/test_navbar.py +11 -34
- nautobot/core/tests/integration/test_plugin_navbar.py +9 -103
- nautobot/core/tests/nautobot_config.py +2 -3
- nautobot/core/tests/runner.py +0 -1
- nautobot/core/tests/test_api.py +290 -24
- nautobot/core/tests/test_authentication.py +57 -14
- nautobot/core/tests/test_checks.py +0 -7
- nautobot/core/tests/test_choices.py +0 -1
- nautobot/core/tests/test_filters.py +117 -110
- nautobot/core/tests/test_forms.py +47 -110
- nautobot/core/tests/test_graphql.py +158 -135
- nautobot/core/tests/test_logging.py +4 -1
- nautobot/core/tests/test_managers.py +3 -5
- nautobot/core/tests/test_models.py +2 -0
- nautobot/core/tests/test_ordering.py +0 -2
- nautobot/core/tests/test_paginator.py +3 -1
- nautobot/core/tests/test_releases.py +12 -12
- nautobot/core/tests/test_templatetags_helpers.py +7 -4
- nautobot/core/tests/test_utils.py +112 -78
- nautobot/core/tests/test_views.py +12 -17
- nautobot/core/tests/test_views_utils.py +6 -9
- nautobot/core/utils/data.py +17 -0
- nautobot/core/utils/deprecation.py +13 -20
- nautobot/core/utils/filtering.py +53 -9
- nautobot/core/utils/git.py +12 -4
- nautobot/core/utils/lookup.py +3 -1
- nautobot/core/utils/requests.py +23 -116
- nautobot/core/views/__init__.py +1 -2
- nautobot/core/views/generic.py +131 -119
- nautobot/core/views/mixins.py +53 -62
- nautobot/core/views/paginator.py +0 -1
- nautobot/core/views/renderers.py +14 -12
- nautobot/core/views/utils.py +87 -4
- nautobot/dcim/api/serializers.py +160 -672
- nautobot/dcim/api/urls.py +1 -1
- nautobot/dcim/api/views.py +7 -46
- nautobot/dcim/choices.py +2 -25
- nautobot/dcim/elevations.py +0 -1
- nautobot/dcim/factory.py +15 -4
- nautobot/dcim/filters/__init__.py +42 -13
- nautobot/dcim/form_mixins.py +1 -27
- nautobot/dcim/forms.py +58 -797
- nautobot/dcim/management/commands/trace_paths.py +0 -1
- nautobot/dcim/migrations/0001_initial_part_1.py +0 -1
- nautobot/dcim/migrations/0002_initial_part_2.py +0 -1
- nautobot/dcim/migrations/0003_initial_part_3.py +0 -1
- nautobot/dcim/migrations/0004_initial_part_4.py +0 -1
- nautobot/dcim/migrations/0005_device_local_context_schema.py +0 -1
- nautobot/dcim/migrations/0006_auto_slug.py +0 -1
- nautobot/dcim/migrations/0007_device_secrets_group.py +0 -1
- nautobot/dcim/migrations/0008_increase_all_serial_lengths.py +0 -1
- nautobot/dcim/migrations/0009_add_natural_indexing.py +0 -1
- nautobot/dcim/migrations/0010_interface_status.py +0 -1
- nautobot/dcim/migrations/0011_interface_status_data_migration.py +0 -1
- nautobot/dcim/migrations/0012_interface_parent_bridge.py +0 -1
- nautobot/dcim/migrations/0013_location_location_type.py +0 -1
- nautobot/dcim/migrations/0014_location_status_data_migration.py +0 -1
- nautobot/dcim/migrations/0015_device_components__changeloggedmodel.py +0 -1
- nautobot/dcim/migrations/0016_device_components__timestamp_data_migration.py +0 -1
- nautobot/dcim/migrations/0017_locationtype_nestable.py +0 -1
- nautobot/dcim/migrations/0018_device_redundancy_group.py +0 -1
- nautobot/dcim/migrations/0019_device_redundancy_group_data_migration.py +0 -1
- nautobot/dcim/migrations/0020_move_site_fields_to_location_model.py +0 -1
- nautobot/dcim/migrations/0021_mptt_to_tree_queries.py +0 -1
- nautobot/dcim/migrations/0022_interface_mac_address_data_migration.py +0 -1
- nautobot/dcim/migrations/0023_alter_interface_mac_address.py +0 -1
- nautobot/dcim/migrations/0024_alter_device_and_rack_role_add_new_role.py +2 -2
- nautobot/dcim/migrations/0025_device_and_rack_roles_data_migrations.py +19 -14
- nautobot/dcim/migrations/0026_rename_device_and_rack_role.py +0 -1
- nautobot/dcim/migrations/0027_remove_device_role_and_rack_role.py +1 -2
- nautobot/dcim/migrations/0028_rename_foreignkey_fields.py +1 -2
- nautobot/dcim/migrations/0029_add_tree_managers_and_foreign_keys_pre_data_migration.py +0 -1
- nautobot/dcim/migrations/0030_migrate_region_and_site_data_to_locations.py +2 -2
- nautobot/dcim/migrations/0031_rename_path_end_point_related_name.py +0 -1
- nautobot/dcim/migrations/0032_remove_site_foreign_key_from_dcim_models.py +0 -1
- nautobot/dcim/migrations/0033_created_datetime.py +0 -1
- nautobot/dcim/migrations/0034_fixup_fks_and_related_names.py +0 -1
- nautobot/dcim/migrations/0035_related_name_changes.py +1 -2
- nautobot/dcim/migrations/0036_remove_region_and_site.py +1 -2
- nautobot/dcim/migrations/0037_interface_ip_addresses_m2m.py +0 -1
- nautobot/dcim/migrations/0038_alter_location_managers.py +0 -1
- nautobot/dcim/migrations/0039_remove_slug.py +24 -0
- nautobot/dcim/migrations/0040_tagsfield.py +109 -0
- nautobot/dcim/migrations/0041_ipam__namespaces.py +25 -0
- nautobot/dcim/migrations/0042_fixup_null_statuses.py +51 -0
- nautobot/dcim/migrations/0043_status_nonnullable.py +72 -0
- nautobot/dcim/models/cables.py +4 -35
- nautobot/dcim/models/device_component_templates.py +7 -2
- nautobot/dcim/models/device_components.py +26 -203
- nautobot/dcim/models/devices.py +30 -152
- nautobot/dcim/models/locations.py +3 -64
- nautobot/dcim/models/power.py +3 -51
- nautobot/dcim/models/racks.py +7 -86
- nautobot/dcim/navigation.py +141 -467
- nautobot/dcim/signals.py +0 -2
- nautobot/dcim/tables/devices.py +8 -5
- nautobot/dcim/tables/devicetypes.py +1 -1
- nautobot/dcim/tables/locations.py +2 -2
- nautobot/dcim/tables/power.py +2 -2
- nautobot/dcim/templates/dcim/console_port_connection_list.html +7 -0
- nautobot/dcim/templates/dcim/device.html +15 -4
- nautobot/dcim/templates/dcim/device_edit.html +6 -0
- nautobot/dcim/templates/dcim/deviceredundancygroup_create.html +0 -1
- nautobot/dcim/templates/dcim/devicetype.html +2 -2
- nautobot/dcim/templates/dcim/interface.html +4 -0
- nautobot/dcim/templates/dcim/interface_connection_list.html +7 -0
- nautobot/dcim/templates/dcim/interface_edit.html +1 -0
- nautobot/dcim/templates/dcim/location.html +16 -1
- nautobot/dcim/templates/dcim/locationtype.html +15 -0
- nautobot/dcim/templates/dcim/power_port_connection_list.html +7 -0
- nautobot/dcim/templates/dcim/rackgroup.html +0 -12
- nautobot/dcim/tests/integration/test_cable_connect_form.py +4 -4
- nautobot/dcim/tests/test_api.py +202 -130
- nautobot/dcim/tests/test_cablepaths.py +47 -42
- nautobot/dcim/tests/test_filters.py +156 -134
- nautobot/dcim/tests/test_forms.py +12 -213
- nautobot/dcim/tests/test_graphql.py +8 -3
- nautobot/dcim/tests/test_migrations.py +6 -11
- nautobot/dcim/tests/test_models.py +208 -158
- nautobot/dcim/tests/test_natural_ordering.py +12 -14
- nautobot/dcim/tests/test_signals.py +7 -4
- nautobot/dcim/tests/test_views.py +270 -264
- nautobot/dcim/urls.py +21 -26
- nautobot/dcim/views.py +14 -156
- nautobot/docs/additional-features/caching.md +6 -87
- nautobot/docs/additional-features/job-scheduling-and-approvals.md +3 -0
- nautobot/docs/additional-features/jobs.md +179 -197
- nautobot/docs/administration/nautobot-server.md +9 -24
- nautobot/docs/administration/nautobot-shell.md +6 -6
- nautobot/docs/administration/replicating-nautobot.md +0 -10
- nautobot/docs/configuration/index.md +9 -9
- nautobot/docs/configuration/optional-settings.md +32 -61
- nautobot/docs/configuration/required-settings.md +11 -52
- nautobot/docs/development/application-registry.md +2 -13
- nautobot/docs/development/best-practices.md +2 -1
- nautobot/docs/development/docker-compose-advanced-use-cases.md +1 -1
- nautobot/docs/development/extending-models.md +15 -17
- nautobot/docs/development/generic-views.md +0 -2
- nautobot/docs/development/getting-started.md +56 -6
- nautobot/docs/development/navigation-menu.md +22 -93
- nautobot/docs/development/react-ui.md +105 -0
- nautobot/docs/development/release-checklist.md +3 -3
- nautobot/docs/development/role-internals.md +1 -3
- nautobot/docs/development/style-guide.md +6 -4
- nautobot/docs/development/templates.md +2 -1
- nautobot/docs/docker/index.md +16 -14
- nautobot/docs/index.md +7 -3
- nautobot/docs/installation/index.md +4 -1
- nautobot/docs/installation/migrating-from-netbox.md +12 -43
- nautobot/docs/installation/migrating-from-postgresql.md +1 -1
- nautobot/docs/installation/nautobot.md +1 -1
- nautobot/docs/installation/tables/v2-api-behavior-changes.yaml +70 -0
- nautobot/docs/installation/tables/v2-api-removed-fields.yaml +142 -0
- nautobot/docs/installation/tables/v2-api-renamed-fields.yaml +124 -0
- nautobot/docs/installation/tables/v2-code-location-changes.yaml +241 -0
- nautobot/docs/installation/tables/v2-code-removals.yaml +67 -0
- nautobot/docs/installation/tables/v2-database-behavior-changes.yaml +37 -0
- nautobot/docs/installation/tables/v2-database-removed-fields.yaml +166 -0
- nautobot/docs/installation/tables/v2-database-renamed-fields.yaml +340 -0
- nautobot/docs/installation/tables/v2-filters-corrected-fields.yaml +28 -0
- nautobot/docs/installation/tables/v2-filters-enhanced-fields.yaml +241 -0
- nautobot/docs/installation/tables/v2-filters-removed-fields.yaml +553 -0
- nautobot/docs/installation/tables/v2-filters-renamed-fields.yaml +223 -0
- nautobot/docs/installation/tables/v2-logging-renamed-loggers.yaml +23 -0
- nautobot/docs/installation/upgrading-from-nautobot-v1.md +190 -636
- nautobot/docs/installation/upgrading.md +5 -2
- nautobot/docs/models/dcim/device.md +3 -0
- nautobot/docs/models/dcim/deviceredundancygroup.md +3 -3
- nautobot/docs/models/extras/computedfield.md +4 -4
- nautobot/docs/models/extras/dynamicgroup.md +9 -9
- nautobot/docs/models/extras/gitrepository.md +3 -0
- nautobot/docs/models/extras/job.md +1 -0
- nautobot/docs/models/extras/jobbutton.md +18 -13
- nautobot/docs/models/extras/jobhook.md +7 -4
- nautobot/docs/models/extras/jobresult.md +6 -2
- nautobot/docs/models/extras/relationship.md +2 -2
- nautobot/docs/models/extras/status.md +6 -19
- nautobot/docs/models/ipam/ipaddress.md +3 -0
- nautobot/docs/models/ipam/vrf.md +0 -3
- nautobot/docs/models/virtualization/virtualmachine.md +3 -0
- nautobot/docs/plugins/development.md +92 -24
- nautobot/docs/release-notes/version-1.5.md +96 -0
- nautobot/docs/release-notes/version-2.0.md +216 -0
- nautobot/docs/requirements.txt +5 -4
- nautobot/docs/rest-api/overview.md +384 -215
- nautobot/docs/rest-api/ui-related-endpoints.md +9 -0
- nautobot/extras/admin.py +3 -5
- nautobot/extras/api/customfields.py +15 -39
- nautobot/extras/api/fields.py +0 -11
- nautobot/extras/api/mixins.py +45 -0
- nautobot/extras/api/relationships.py +63 -159
- nautobot/extras/api/serializers.py +165 -706
- nautobot/extras/api/urls.py +1 -1
- nautobot/extras/api/views.py +295 -282
- nautobot/extras/apps.py +4 -7
- nautobot/extras/choices.py +11 -22
- nautobot/extras/constants.py +9 -3
- nautobot/extras/datasources/__init__.py +2 -0
- nautobot/extras/datasources/git.py +135 -186
- nautobot/extras/datasources/registry.py +25 -35
- nautobot/extras/factory.py +1 -3
- nautobot/extras/filters/__init__.py +49 -47
- nautobot/extras/filters/mixins.py +10 -8
- nautobot/extras/forms/forms.py +72 -148
- nautobot/extras/forms/mixins.py +34 -57
- nautobot/extras/health_checks.py +0 -33
- nautobot/extras/jobs.py +387 -566
- nautobot/extras/management/__init__.py +55 -48
- nautobot/extras/management/commands/renaturalize.py +0 -1
- nautobot/extras/management/commands/runjob.py +24 -62
- nautobot/extras/management/commands/webhook_receiver.py +0 -1
- nautobot/extras/managers.py +30 -7
- nautobot/extras/migrations/0001_initial_part_1.py +0 -1
- nautobot/extras/migrations/0002_initial_part_2.py +0 -1
- nautobot/extras/migrations/0003_initial_part_3.py +0 -1
- nautobot/extras/migrations/0004_populate_default_status_records.py +0 -1
- nautobot/extras/migrations/0005_configcontext_device_types.py +0 -1
- nautobot/extras/migrations/0006_graphqlquery.py +0 -1
- nautobot/extras/migrations/0007_configcontextschema.py +0 -1
- nautobot/extras/migrations/0008_jobresult__custom_field_data.py +0 -1
- nautobot/extras/migrations/0009_computedfield.py +0 -1
- nautobot/extras/migrations/0010_change_cf_validation_max_min_field_to_bigint.py +0 -1
- nautobot/extras/migrations/0011_fileattachment_fileproxy.py +0 -1
- nautobot/extras/migrations/0012_healthchecktestmodel.py +0 -1
- nautobot/extras/migrations/0013_default_fallback_value_computedfield.py +0 -1
- nautobot/extras/migrations/0014_auto_slug.py +0 -1
- nautobot/extras/migrations/0015_scheduled_job.py +0 -1
- nautobot/extras/migrations/0016_secret.py +0 -1
- nautobot/extras/migrations/0017_joblogentry.py +0 -1
- nautobot/extras/migrations/0018_joblog_data_migration.py +0 -2
- nautobot/extras/migrations/0019_joblogentry__meta_options__related_name.py +0 -1
- nautobot/extras/migrations/0020_customfield_changelog.py +0 -1
- nautobot/extras/migrations/0021_customfield_changelog_data.py +0 -1
- nautobot/extras/migrations/0022_objectchange_object_datav2.py +0 -1
- nautobot/extras/migrations/0023_job_model.py +0 -1
- nautobot/extras/migrations/0024_job_data_migration.py +0 -1
- nautobot/extras/migrations/0025_add_advanced_ui_boolean_to_customfield_conputedfield_and_relationship.py +0 -1
- nautobot/extras/migrations/0026_job_add_gitrepository_fk.py +0 -1
- nautobot/extras/migrations/0027_job_gitrepository_data_migration.py +0 -1
- nautobot/extras/migrations/0028_job_reduce_source.py +0 -1
- nautobot/extras/migrations/0029_dynamicgroup.py +0 -1
- nautobot/extras/migrations/0030_webhook_alter_unique_together.py +0 -1
- nautobot/extras/migrations/0031_tag_content_types.py +0 -1
- nautobot/extras/migrations/0032_tag_content_types_data_migration.py +0 -1
- nautobot/extras/migrations/0033_add__optimized_indexing.py +0 -1
- nautobot/extras/migrations/0034_alter_fileattachment_mimetype.py +0 -1
- nautobot/extras/migrations/0035_scheduledjob_crontab.py +0 -1
- nautobot/extras/migrations/0036_job_add_has_sensitive_variables.py +0 -1
- nautobot/extras/migrations/0037_configcontextschema__remove_name_unique__create_constraint_unique_name_owner.py +0 -1
- nautobot/extras/migrations/0038_configcontext_locations.py +0 -1
- nautobot/extras/migrations/0039_objectchange__add_change_context.py +0 -1
- nautobot/extras/migrations/0040_dynamicgroup__dynamicgroupmembership.py +0 -1
- nautobot/extras/migrations/0041_jobresult_job_kwargs.py +0 -1
- nautobot/extras/migrations/0042_job__add_is_job_hook_receiver.py +0 -1
- nautobot/extras/migrations/0043_note.py +0 -1
- nautobot/extras/migrations/0044_add_job_hook.py +0 -1
- nautobot/extras/migrations/0045_add_custom_field_slug.py +0 -1
- nautobot/extras/migrations/0046_populate_custom_field_slug_label.py +0 -1
- nautobot/extras/migrations/0047_enforce_custom_field_slug.py +0 -1
- nautobot/extras/migrations/0048_alter_objectchange_change_context_detail.py +0 -1
- nautobot/extras/migrations/0049_alter_tag_slug.py +0 -1
- nautobot/extras/migrations/0050_customfield_grouping.py +0 -1
- nautobot/extras/migrations/0051_add_job_task_queues.py +0 -1
- nautobot/extras/migrations/0052_configcontext_device_redundancy_groups.py +0 -1
- nautobot/extras/migrations/0053_relationship_required_on.py +0 -1
- nautobot/extras/migrations/0054_scheduledjob_kwargs_request_user_change.py +0 -1
- nautobot/extras/migrations/0055_configcontext_dynamic_groups.py +0 -1
- nautobot/extras/migrations/0056_objectchange_add_reverse_time_idx.py +0 -1
- nautobot/extras/migrations/0057_jobbutton.py +0 -1
- nautobot/extras/migrations/0058_jobresult_add_time_status_idxs.py +38 -0
- nautobot/extras/migrations/{0058_joblogentry_scheduledjob_webhook_data_migration.py → 0059_joblogentry_scheduledjob_webhook_data_migration.py} +1 -2
- nautobot/extras/migrations/{0059_alter_joblogentry_scheduledjob_webhook_fields.py → 0060_alter_joblogentry_scheduledjob_webhook_fields.py} +1 -2
- nautobot/extras/migrations/{0060_role_and_alter_status.py → 0061_role_and_alter_status.py} +1 -8
- nautobot/extras/migrations/{0061_collect_roles_from_related_apps_roles.py → 0062_collect_roles_from_related_apps_roles.py} +33 -33
- nautobot/extras/migrations/{0062_alter_role_options.py → 0063_alter_role_options.py} +1 -2
- nautobot/extras/migrations/{0063_alter_configcontext_and_add_new_role.py → 0064_alter_configcontext_and_add_new_role.py} +1 -2
- nautobot/extras/migrations/0065_configcontext_data_migrations.py +44 -0
- nautobot/extras/migrations/{0065_rename_configcontext_role.py → 0066_rename_configcontext_role.py} +1 -2
- nautobot/extras/migrations/{0066_jobresult__add_celery_fields.py → 0067_jobresult__add_celery_fields.py} +36 -3
- nautobot/extras/migrations/{0067_created_datetime.py → 0068_created_datetime.py} +1 -2
- nautobot/extras/migrations/{0068_remove_site_and_region_attributes_from_config_context.py → 0069_remove_site_and_region_attributes_from_config_context.py} +1 -2
- nautobot/extras/migrations/{0069_replace_related_names.py → 0070_replace_related_names.py} +1 -1
- nautobot/extras/migrations/{0070_rename_model_fields.py → 0071_rename_model_fields.py} +1 -2
- nautobot/extras/migrations/0072_job__unique_name_data_migration.py +86 -0
- nautobot/extras/migrations/{0072_job__unique_name.py → 0073_job__unique_name.py} +13 -10
- nautobot/extras/migrations/{0073_remove_gitrepository_fields.py → 0074_remove_gitrepository_fields.py} +1 -2
- nautobot/extras/migrations/{0074_rename_slug_to_key_for_custom_field.py → 0075_rename_slug_to_key_for_custom_field.py} +1 -1
- nautobot/extras/migrations/{0075_migrate_custom_field_data.py → 0076_migrate_custom_field_data.py} +1 -1
- nautobot/extras/migrations/{0076_remove_name_field_and_make_label_field_non_nullable.py → 0077_remove_name_field_and_make_label_field_non_nullable.py} +1 -1
- nautobot/extras/migrations/0078_remove_slug.py +45 -0
- nautobot/extras/migrations/0079_tagsfield.py +28 -0
- nautobot/extras/migrations/0080_rename_relationship_slug_to_key.py +17 -0
- nautobot/extras/migrations/0081_rename_relationship_name_to_label.py +29 -0
- nautobot/extras/migrations/0082_ensure_relationship_keys_are_unique.py +43 -0
- nautobot/extras/migrations/0083_rename_computed_field_slug_to_key.py +21 -0
- nautobot/extras/migrations/0084_taggeditem_cleanup.py +43 -0
- nautobot/extras/migrations/0085_taggeditem_uniqueness.py +22 -0
- nautobot/extras/migrations/0086_job__celery_task_fields__dryrun_support.py +81 -0
- nautobot/extras/migrations/0087_job__commit_default_data_migration.py +26 -0
- nautobot/extras/migrations/0088_joblogentry__log_level_default.py +17 -0
- nautobot/extras/migrations/0089_joblogentry__log_level_data_migration.py +34 -0
- nautobot/extras/migrations/0090_scheduledjob__data_migration.py +57 -0
- nautobot/extras/models/__init__.py +2 -3
- nautobot/extras/models/change_logging.py +0 -36
- nautobot/extras/models/customfields.py +39 -33
- nautobot/extras/models/datasources.py +48 -50
- nautobot/extras/models/groups.py +5 -12
- nautobot/extras/models/jobs.py +190 -323
- nautobot/extras/models/mixins.py +0 -71
- nautobot/extras/models/models.py +1 -22
- nautobot/extras/models/relationships.py +20 -21
- nautobot/extras/models/roles.py +0 -23
- nautobot/extras/models/secrets.py +2 -31
- nautobot/extras/models/statuses.py +6 -5
- nautobot/extras/models/tags.py +2 -17
- nautobot/extras/navigation.py +89 -307
- nautobot/extras/plugins/__init__.py +3 -121
- nautobot/extras/plugins/utils.py +0 -3
- nautobot/extras/plugins/validators.py +5 -4
- nautobot/extras/plugins/views.py +16 -4
- nautobot/extras/querysets.py +1 -7
- nautobot/extras/registry.py +3 -0
- nautobot/extras/signals.py +26 -60
- nautobot/extras/tables.py +42 -49
- nautobot/extras/tasks.py +0 -12
- nautobot/extras/templates/extras/configcontext.html +1 -1
- nautobot/extras/templates/extras/configcontextschema.html +16 -1
- nautobot/extras/templates/extras/customfield.html +0 -13
- nautobot/extras/templates/extras/dynamicgroup_edit.html +0 -1
- nautobot/extras/templates/extras/gitrepository.html +3 -3
- nautobot/extras/templates/extras/inc/jobresult.html +10 -0
- nautobot/extras/templates/extras/inc/panel_jobhistory.html +1 -1
- nautobot/extras/templates/extras/job.html +35 -25
- nautobot/extras/templates/extras/job_approval_request.html +15 -30
- nautobot/extras/templates/extras/job_detail.html +13 -31
- nautobot/extras/templates/extras/job_edit.html +14 -17
- nautobot/extras/templates/extras/jobresult.html +24 -6
- nautobot/extras/templates/extras/objectchange_list.html +1 -1
- nautobot/extras/templates/extras/scheduledjob.html +2 -2
- nautobot/extras/templates/extras/secret.html +28 -0
- nautobot/extras/templates/extras/secret_edit.html +0 -1
- nautobot/extras/templates/extras/secretsgroup_edit.html +0 -1
- nautobot/extras/templatetags/custom_links.py +0 -2
- nautobot/extras/templatetags/job_buttons.py +1 -0
- nautobot/extras/templatetags/plugins.py +0 -1
- nautobot/extras/{tests/example_jobs → test_jobs}/api_test_job.py +13 -6
- nautobot/extras/test_jobs/atomic_transaction.py +53 -0
- nautobot/extras/test_jobs/dry_run.py +29 -0
- nautobot/extras/{tests/example_jobs/test_duplicate_name.py → test_jobs/duplicate_name.py} +4 -0
- nautobot/extras/test_jobs/duplicate_name2.py +9 -0
- nautobot/extras/test_jobs/fail.py +23 -0
- nautobot/extras/{tests/example_jobs/test_field_default.py → test_jobs/field_default.py} +4 -0
- nautobot/extras/{tests/example_jobs/test_field_order.py → test_jobs/field_order.py} +4 -0
- nautobot/extras/{tests/example_jobs/test_file_upload_fail.py → test_jobs/file_upload_fail.py} +11 -6
- nautobot/extras/test_jobs/file_upload_pass.py +25 -0
- nautobot/extras/test_jobs/has_sensitive_variables.py +25 -0
- nautobot/extras/test_jobs/ipaddress_vars.py +66 -0
- nautobot/extras/test_jobs/job_button_receiver.py +28 -0
- nautobot/extras/test_jobs/job_hook_receiver.py +29 -0
- nautobot/extras/test_jobs/job_variables.py +88 -0
- nautobot/extras/test_jobs/location_with_custom_field.py +45 -0
- nautobot/extras/test_jobs/log_redaction.py +20 -0
- nautobot/extras/test_jobs/log_skip_db_logging.py +17 -0
- nautobot/extras/test_jobs/modify_db.py +25 -0
- nautobot/extras/{tests/example_jobs/test_no_field_order.py → test_jobs/no_field_order.py} +4 -0
- nautobot/extras/test_jobs/object_var_optional.py +21 -0
- nautobot/extras/test_jobs/object_var_required.py +21 -0
- nautobot/extras/test_jobs/object_vars.py +26 -0
- nautobot/extras/test_jobs/pass.py +25 -0
- nautobot/extras/test_jobs/profiling.py +32 -0
- nautobot/extras/test_jobs/read_only_job.py +15 -0
- nautobot/extras/{tests/example_jobs/test_required_args.py → test_jobs/required_args.py} +4 -0
- nautobot/extras/{tests/example_jobs/test_soft_time_limit_greater_than_time_limit.py → test_jobs/soft_time_limit_greater_than_time_limit.py} +5 -1
- nautobot/extras/{tests/example_jobs/test_task_queues.py → test_jobs/task_queues.py} +5 -1
- nautobot/extras/tests/integration/__init__.py +3 -3
- nautobot/extras/tests/integration/test_computedfields.py +1 -1
- nautobot/extras/tests/integration/test_configcontextschema.py +7 -5
- nautobot/extras/tests/integration/test_customfields.py +4 -2
- nautobot/extras/tests/integration/test_dynamicgroups.py +2 -2
- nautobot/extras/tests/integration/test_jobs.py +25 -27
- nautobot/extras/tests/integration/test_notes.py +8 -4
- nautobot/extras/tests/integration/test_plugins.py +4 -4
- nautobot/extras/tests/integration/test_relationships.py +2 -2
- nautobot/extras/tests/test_api.py +371 -381
- nautobot/extras/tests/test_changelog.py +17 -16
- nautobot/extras/tests/test_context_managers.py +5 -6
- nautobot/extras/tests/test_customfields.py +112 -73
- nautobot/extras/tests/test_datasources.py +191 -117
- nautobot/extras/tests/test_dynamicgroups.py +45 -68
- nautobot/extras/tests/test_filters.py +170 -130
- nautobot/extras/tests/test_forms.py +107 -109
- nautobot/extras/tests/{test_scripts.py → test_job_variables.py} +43 -49
- nautobot/extras/tests/test_jobs.py +271 -273
- nautobot/extras/tests/test_management.py +3 -6
- nautobot/extras/tests/test_migrations.py +5 -3
- nautobot/extras/tests/test_models.py +121 -173
- nautobot/extras/tests/test_notes.py +0 -1
- nautobot/extras/tests/test_plugins.py +55 -89
- nautobot/extras/tests/test_relationships.py +174 -130
- nautobot/extras/tests/test_tags.py +6 -12
- nautobot/extras/tests/test_utils.py +31 -1
- nautobot/extras/tests/test_views.py +223 -184
- nautobot/extras/tests/test_webhooks.py +16 -15
- nautobot/extras/urls.py +69 -69
- nautobot/extras/utils.py +137 -163
- nautobot/extras/views.py +81 -153
- nautobot/ipam/api/fields.py +17 -0
- nautobot/ipam/api/serializers.py +77 -164
- nautobot/ipam/api/urls.py +4 -1
- nautobot/ipam/api/views.py +28 -19
- nautobot/ipam/apps.py +1 -0
- nautobot/ipam/choices.py +5 -12
- nautobot/ipam/constants.py +1 -0
- nautobot/ipam/factory.py +41 -30
- nautobot/ipam/filters.py +58 -25
- nautobot/ipam/forms.py +82 -211
- nautobot/ipam/graphql/types.py +0 -9
- nautobot/ipam/lookups.py +13 -8
- nautobot/ipam/management/commands/__init__.py +0 -0
- nautobot/ipam/management/commands/fix_prefix_broadcast.py +17 -0
- nautobot/ipam/migrations/0001_initial_part_1.py +0 -1
- nautobot/ipam/migrations/0002_initial_part_2.py +0 -1
- nautobot/ipam/migrations/0003_remove_max_length.py +0 -1
- nautobot/ipam/migrations/0004_fixup_p2p_broadcast.py +0 -1
- nautobot/ipam/migrations/0005_auto_slug.py +0 -1
- nautobot/ipam/migrations/0006_ipaddress_nat_outside_list.py +0 -1
- nautobot/ipam/migrations/0007_add_natural_indexing.py +0 -1
- nautobot/ipam/migrations/0008_prefix_vlan_vlangroup_location.py +0 -1
- nautobot/ipam/migrations/0009_alter_vlan_name.py +0 -1
- nautobot/ipam/migrations/0010_alter_ipam_role_add_new_role.py +1 -2
- nautobot/ipam/migrations/0011_migrate_ipam_role_data.py +32 -39
- nautobot/ipam/migrations/0012_rename_ipam_roles.py +0 -1
- nautobot/ipam/migrations/0013_delete_role.py +0 -1
- nautobot/ipam/migrations/0014_rename_foreign_keys_and_related_names.py +0 -1
- nautobot/ipam/migrations/0015_prefix_add_type.py +0 -1
- nautobot/ipam/migrations/0016_prefix_type_data_migration.py +0 -3
- nautobot/ipam/migrations/0017_prefix_remove_is_pool.py +0 -1
- nautobot/ipam/migrations/0018_remove_site_foreign_key_from_ipam_models.py +0 -1
- nautobot/ipam/migrations/0019_created_datetime.py +0 -1
- nautobot/ipam/migrations/0020_related_name_changes.py +1 -2
- nautobot/ipam/migrations/0021_prefix_add_rir_and_date_allocated.py +0 -1
- nautobot/ipam/migrations/0022_aggregate_to_prefix_data_migration.py +3 -5
- nautobot/ipam/migrations/0023_delete_aggregate.py +0 -1
- nautobot/ipam/migrations/0024_interface_to_ipaddress_m2m.py +0 -1
- nautobot/ipam/migrations/0025_interface_ipaddress_m2m_data_migration.py +0 -1
- nautobot/ipam/migrations/0026_ipaddress_remove_assigned_object.py +0 -1
- nautobot/ipam/migrations/0027_remove_rir_slug.py +16 -0
- nautobot/ipam/migrations/0028_tagsfield.py +44 -0
- nautobot/ipam/migrations/0029_ip_address_to_interface_uniqueness_constraints.py +18 -0
- nautobot/ipam/migrations/0030_ipam__namespaces.py +231 -0
- nautobot/ipam/migrations/0031_ipam__prefix__add_parent.py +58 -0
- nautobot/ipam/migrations/0032_ipam__namespaces_finish.py +63 -0
- nautobot/ipam/migrations/0033_fixup_null_statuses.py +26 -0
- nautobot/ipam/migrations/0034_status_nonnullable.py +36 -0
- nautobot/ipam/models.py +579 -368
- nautobot/ipam/navigation.py +36 -159
- nautobot/ipam/querysets.py +117 -90
- nautobot/ipam/signals.py +89 -0
- nautobot/ipam/tables.py +86 -28
- nautobot/ipam/templates/ipam/ipaddress.html +14 -30
- nautobot/ipam/templates/ipam/ipaddress_edit.html +1 -0
- nautobot/ipam/templates/ipam/namespace_ipaddresses.html +11 -0
- nautobot/ipam/templates/ipam/namespace_prefixes.html +11 -0
- nautobot/ipam/templates/ipam/namespace_retrieve.html +42 -0
- nautobot/ipam/templates/ipam/namespace_vrfs.html +11 -0
- nautobot/ipam/templates/ipam/prefix.html +27 -33
- nautobot/ipam/templates/ipam/prefix_edit.html +7 -1
- nautobot/ipam/templates/ipam/vlangroup.html +0 -13
- nautobot/ipam/templates/ipam/vrf.html +6 -4
- nautobot/ipam/templates/ipam/vrf_edit.html +20 -2
- nautobot/ipam/tests/integration/test_prefixes.py +4 -27
- nautobot/ipam/tests/test_api.py +60 -61
- nautobot/ipam/tests/test_filters.py +187 -126
- nautobot/ipam/tests/test_forms.py +12 -6
- nautobot/ipam/tests/test_graphql.py +8 -6
- nautobot/ipam/tests/test_migrations.py +8 -13
- nautobot/ipam/tests/test_models.py +426 -274
- nautobot/ipam/tests/test_ordering.py +6 -3
- nautobot/ipam/tests/test_querysets.py +340 -96
- nautobot/ipam/tests/test_views.py +100 -55
- nautobot/ipam/urls.py +28 -5
- nautobot/ipam/{utils.py → utils/__init__.py} +2 -2
- nautobot/ipam/utils/migrations.py +713 -0
- nautobot/ipam/views.py +237 -122
- nautobot/project-static/docs/404.html +1399 -166
- nautobot/project-static/docs/additional-features/caching.html +1416 -320
- nautobot/project-static/docs/additional-features/change-logging.html +1389 -190
- nautobot/project-static/docs/additional-features/config-contexts.html +1389 -190
- nautobot/project-static/docs/additional-features/graphql.html +1389 -190
- nautobot/project-static/docs/additional-features/healthcheck.html +1389 -190
- nautobot/project-static/docs/additional-features/job-scheduling-and-approvals.html +1393 -190
- nautobot/project-static/docs/additional-features/jobs.html +1677 -460
- nautobot/project-static/docs/additional-features/napalm.html +1389 -190
- nautobot/project-static/docs/additional-features/prometheus-metrics.html +1389 -190
- nautobot/project-static/docs/additional-features/template-filters.html +1389 -190
- nautobot/project-static/docs/administration/celery-queues.html +1389 -190
- nautobot/project-static/docs/administration/nautobot-server.html +1553 -375
- nautobot/project-static/docs/administration/nautobot-shell.html +1395 -196
- nautobot/project-static/docs/administration/permissions.html +1389 -190
- nautobot/project-static/docs/administration/replicating-nautobot.html +1387 -207
- nautobot/project-static/docs/apps/index.html +1389 -190
- nautobot/project-static/docs/apps/nautobot-apps.html +1387 -175
- nautobot/project-static/docs/assets/javascripts/bundle.51198bba.min.js +29 -0
- nautobot/project-static/docs/assets/javascripts/bundle.51198bba.min.js.map +8 -0
- nautobot/project-static/docs/assets/javascripts/workers/{search.16e2a7d4.min.js → search.208ed371.min.js} +9 -15
- nautobot/project-static/docs/assets/javascripts/workers/{search.16e2a7d4.min.js.map → search.208ed371.min.js.map} +4 -4
- nautobot/project-static/docs/assets/stylesheets/main.ded33207.min.css +1 -0
- nautobot/project-static/docs/assets/stylesheets/main.ded33207.min.css.map +1 -0
- nautobot/project-static/docs/assets/stylesheets/palette.a0c5b2b5.min.css +1 -0
- nautobot/project-static/docs/assets/stylesheets/palette.a0c5b2b5.min.css.map +1 -0
- nautobot/project-static/docs/code-reference/nautobot/apps/__init__.html +1775 -590
- nautobot/project-static/docs/code-reference/nautobot/apps/admin.html +1389 -190
- nautobot/project-static/docs/code-reference/nautobot/apps/api.html +3588 -1922
- nautobot/project-static/docs/code-reference/nautobot/apps/choices.html +1461 -262
- nautobot/project-static/docs/code-reference/nautobot/apps/config.html +1401 -170
- nautobot/project-static/docs/code-reference/nautobot/apps/datasources.html +1396 -191
- nautobot/project-static/docs/code-reference/nautobot/apps/filters.html +2095 -894
- nautobot/project-static/docs/code-reference/nautobot/apps/forms.html +2357 -1194
- nautobot/project-static/docs/code-reference/nautobot/apps/models.html +2258 -940
- nautobot/project-static/docs/code-reference/nautobot/apps/secrets.html +1389 -190
- nautobot/project-static/docs/code-reference/nautobot/apps/tables.html +1400 -201
- nautobot/project-static/docs/code-reference/nautobot/apps/testing.html +11068 -7861
- nautobot/project-static/docs/code-reference/nautobot/apps/ui.html +2867 -2224
- nautobot/project-static/docs/code-reference/nautobot/apps/urls.html +1389 -190
- nautobot/project-static/docs/code-reference/nautobot/apps/views.html +2641 -1573
- nautobot/project-static/docs/configuration/authentication/ldap.html +1389 -190
- nautobot/project-static/docs/configuration/authentication/remote.html +1389 -190
- nautobot/project-static/docs/configuration/authentication/sso.html +1389 -190
- nautobot/project-static/docs/configuration/index.html +1398 -199
- nautobot/project-static/docs/configuration/optional-settings.html +1418 -274
- nautobot/project-static/docs/configuration/required-settings.html +1419 -287
- nautobot/project-static/docs/core-functionality/circuits.html +1446 -247
- nautobot/project-static/docs/core-functionality/device-types.html +1448 -249
- nautobot/project-static/docs/core-functionality/devices.html +1452 -249
- nautobot/project-static/docs/core-functionality/ipam.html +1452 -253
- nautobot/project-static/docs/core-functionality/power.html +1448 -249
- nautobot/project-static/docs/core-functionality/secrets.html +1448 -249
- nautobot/project-static/docs/core-functionality/services.html +1448 -249
- nautobot/project-static/docs/core-functionality/sites-and-racks.html +1448 -249
- nautobot/project-static/docs/core-functionality/tenancy.html +1448 -249
- nautobot/project-static/docs/core-functionality/virtualization.html +1452 -249
- nautobot/project-static/docs/core-functionality/vlans.html +1448 -249
- nautobot/project-static/docs/development/application-registry.html +1393 -214
- nautobot/project-static/docs/development/best-practices.html +1392 -192
- nautobot/project-static/docs/development/docker-compose-advanced-use-cases.html +1390 -191
- nautobot/project-static/docs/development/extending-models.html +1443 -257
- nautobot/project-static/docs/development/generic-views.html +1403 -174
- nautobot/project-static/docs/development/getting-started.html +1568 -262
- nautobot/project-static/docs/development/homepage.html +1389 -190
- nautobot/project-static/docs/development/index.html +1389 -190
- nautobot/project-static/docs/development/model-features.html +1389 -190
- nautobot/project-static/docs/development/natural-keys.html +1389 -190
- nautobot/project-static/docs/development/navigation-menu.html +1451 -330
- nautobot/project-static/docs/development/react-ui.html +4199 -0
- nautobot/project-static/docs/development/release-checklist.html +1392 -193
- nautobot/project-static/docs/development/role-internals.html +1402 -172
- nautobot/project-static/docs/development/style-guide.html +1399 -199
- nautobot/project-static/docs/development/templates.html +1391 -191
- nautobot/project-static/docs/development/testing.html +1389 -190
- nautobot/project-static/docs/development/user-preferences.html +1389 -190
- nautobot/project-static/docs/docker/index.html +1408 -206
- nautobot/project-static/docs/index.html +1397 -180
- nautobot/project-static/docs/installation/centos.html +1401 -170
- nautobot/project-static/docs/installation/external-authentication.html +1389 -190
- nautobot/project-static/docs/installation/http-server.html +1389 -190
- nautobot/project-static/docs/installation/index.html +1394 -191
- nautobot/project-static/docs/installation/migrating-from-netbox.html +1452 -305
- nautobot/project-static/docs/installation/migrating-from-postgresql.html +1390 -191
- nautobot/project-static/docs/installation/nautobot.html +1390 -191
- nautobot/project-static/docs/installation/region-and-site-data-migration-guide.html +1389 -190
- nautobot/project-static/docs/installation/selinux-troubleshooting.html +1401 -170
- nautobot/project-static/docs/installation/services.html +1389 -190
- nautobot/project-static/docs/installation/tables/v2-api-behavior-changes.yaml +70 -0
- nautobot/project-static/docs/installation/tables/v2-api-removed-fields.yaml +142 -0
- nautobot/project-static/docs/installation/tables/v2-api-renamed-fields.yaml +124 -0
- nautobot/project-static/docs/installation/tables/v2-code-location-changes.yaml +241 -0
- nautobot/project-static/docs/installation/tables/v2-code-removals.yaml +67 -0
- nautobot/project-static/docs/installation/tables/v2-database-behavior-changes.yaml +37 -0
- nautobot/project-static/docs/installation/tables/v2-database-removed-fields.yaml +166 -0
- nautobot/project-static/docs/installation/tables/v2-database-renamed-fields.yaml +340 -0
- nautobot/project-static/docs/installation/tables/v2-filters-corrected-fields.yaml +28 -0
- nautobot/project-static/docs/installation/tables/v2-filters-enhanced-fields.yaml +241 -0
- nautobot/project-static/docs/installation/tables/v2-filters-removed-fields.yaml +553 -0
- nautobot/project-static/docs/installation/tables/v2-filters-renamed-fields.yaml +223 -0
- nautobot/project-static/docs/installation/tables/v2-logging-renamed-loggers.yaml +23 -0
- nautobot/project-static/docs/installation/ubuntu.html +1401 -170
- nautobot/project-static/docs/installation/upgrading-from-nautobot-v1.html +4254 -1923
- nautobot/project-static/docs/installation/upgrading.html +1395 -192
- nautobot/project-static/docs/models/circuits/circuit.html +1427 -174
- nautobot/project-static/docs/models/circuits/circuittermination.html +1427 -174
- nautobot/project-static/docs/models/circuits/circuittype.html +1427 -174
- nautobot/project-static/docs/models/circuits/provider.html +1427 -174
- nautobot/project-static/docs/models/circuits/providernetwork.html +1427 -174
- nautobot/project-static/docs/models/dcim/cable.html +1458 -174
- nautobot/project-static/docs/models/dcim/consoleport.html +1427 -174
- nautobot/project-static/docs/models/dcim/consoleporttemplate.html +1427 -174
- nautobot/project-static/docs/models/dcim/consoleserverport.html +1427 -174
- nautobot/project-static/docs/models/dcim/consoleserverporttemplate.html +1427 -174
- nautobot/project-static/docs/models/dcim/device.html +1431 -174
- nautobot/project-static/docs/models/dcim/devicebay.html +1427 -174
- nautobot/project-static/docs/models/dcim/devicebaytemplate.html +1427 -174
- nautobot/project-static/docs/models/dcim/deviceredundancygroup.html +1522 -177
- nautobot/project-static/docs/models/dcim/devicetype.html +1427 -174
- nautobot/project-static/docs/models/dcim/frontport.html +1427 -174
- nautobot/project-static/docs/models/dcim/frontporttemplate.html +1427 -174
- nautobot/project-static/docs/models/dcim/interface.html +1427 -174
- nautobot/project-static/docs/models/dcim/interfacetemplate.html +1427 -174
- nautobot/project-static/docs/models/dcim/inventoryitem.html +1427 -174
- nautobot/project-static/docs/models/dcim/location.html +1427 -174
- nautobot/project-static/docs/models/dcim/locationtype.html +1427 -174
- nautobot/project-static/docs/models/dcim/manufacturer.html +1427 -174
- nautobot/project-static/docs/models/dcim/platform.html +1427 -174
- nautobot/project-static/docs/models/dcim/powerfeed.html +1425 -172
- nautobot/project-static/docs/models/dcim/poweroutlet.html +1427 -174
- nautobot/project-static/docs/models/dcim/poweroutlettemplate.html +1427 -174
- nautobot/project-static/docs/models/dcim/powerpanel.html +1425 -172
- nautobot/project-static/docs/models/dcim/powerport.html +1427 -174
- nautobot/project-static/docs/models/dcim/powerporttemplate.html +1427 -174
- nautobot/project-static/docs/models/dcim/rack.html +1427 -174
- nautobot/project-static/docs/models/dcim/rackgroup.html +1427 -174
- nautobot/project-static/docs/models/dcim/rackreservation.html +1427 -174
- nautobot/project-static/docs/models/dcim/rearport.html +1427 -174
- nautobot/project-static/docs/models/dcim/rearporttemplate.html +1427 -174
- nautobot/project-static/docs/models/dcim/region.html +1401 -170
- nautobot/project-static/docs/models/dcim/site.html +1401 -170
- nautobot/project-static/docs/models/dcim/virtualchassis.html +1425 -172
- nautobot/project-static/docs/models/extras/computedfield.html +1393 -194
- nautobot/project-static/docs/models/extras/configcontext.html +1465 -174
- nautobot/project-static/docs/models/extras/configcontextschema.html +1421 -168
- nautobot/project-static/docs/models/extras/customfield.html +1389 -190
- nautobot/project-static/docs/models/extras/customlink.html +1389 -190
- nautobot/project-static/docs/models/extras/dynamicgroup.html +1398 -199
- nautobot/project-static/docs/models/extras/exporttemplate.html +1389 -190
- nautobot/project-static/docs/models/extras/gitrepository.html +1393 -190
- nautobot/project-static/docs/models/extras/graphqlquery.html +1469 -171
- nautobot/project-static/docs/models/extras/imageattachment.html +1434 -181
- nautobot/project-static/docs/models/extras/job.html +1411 -157
- nautobot/project-static/docs/models/extras/jobbutton.html +1410 -207
- nautobot/project-static/docs/models/extras/jobhook.html +1397 -194
- nautobot/project-static/docs/models/extras/joblogentry.html +1408 -155
- nautobot/project-static/docs/models/extras/jobresult.html +1417 -159
- nautobot/project-static/docs/models/extras/note.html +1389 -190
- nautobot/project-static/docs/models/extras/relationship.html +1391 -192
- nautobot/project-static/docs/models/extras/role.html +1495 -198
- nautobot/project-static/docs/models/extras/secret.html +1492 -201
- nautobot/project-static/docs/models/extras/secretsgroup.html +1410 -157
- nautobot/project-static/docs/models/extras/status.html +1381 -221
- nautobot/project-static/docs/models/extras/tag.html +1389 -190
- nautobot/project-static/docs/models/extras/webhook.html +1389 -190
- nautobot/project-static/docs/models/ipam/ipaddress.html +1488 -200
- nautobot/project-static/docs/models/ipam/prefix.html +1410 -157
- nautobot/project-static/docs/models/ipam/rir.html +1410 -157
- nautobot/project-static/docs/models/ipam/routetarget.html +1410 -157
- nautobot/project-static/docs/models/ipam/service.html +1410 -157
- nautobot/project-static/docs/models/ipam/vlan.html +1410 -157
- nautobot/project-static/docs/models/ipam/vlangroup.html +1410 -157
- nautobot/project-static/docs/models/ipam/vrf.html +1410 -161
- nautobot/project-static/docs/models/tenancy/tenant.html +1412 -159
- nautobot/project-static/docs/models/tenancy/tenantgroup.html +1412 -159
- nautobot/project-static/docs/models/users/objectpermission.html +1462 -171
- nautobot/project-static/docs/models/users/token.html +1410 -157
- nautobot/project-static/docs/models/virtualization/cluster.html +1410 -157
- nautobot/project-static/docs/models/virtualization/clustergroup.html +1410 -157
- nautobot/project-static/docs/models/virtualization/clustertype.html +1410 -157
- nautobot/project-static/docs/models/virtualization/virtualmachine.html +1414 -157
- nautobot/project-static/docs/models/virtualization/vminterface.html +1410 -157
- nautobot/project-static/docs/objects.inv +0 -0
- nautobot/project-static/docs/plugins/development.html +1916 -646
- nautobot/project-static/docs/plugins/index.html +1389 -190
- nautobot/project-static/docs/plugins/porting-from-netbox.html +1389 -190
- nautobot/project-static/docs/release-notes/index.html +1389 -190
- nautobot/project-static/docs/release-notes/version-1.0.html +1389 -190
- nautobot/project-static/docs/release-notes/version-1.1.html +1389 -190
- nautobot/project-static/docs/release-notes/version-1.2.html +1389 -190
- nautobot/project-static/docs/release-notes/version-1.3.html +1389 -190
- nautobot/project-static/docs/release-notes/version-1.4.html +1389 -190
- nautobot/project-static/docs/release-notes/version-1.5.html +2016 -397
- nautobot/project-static/docs/release-notes/version-2.0.html +1935 -287
- nautobot/project-static/docs/requirements.txt +5 -4
- nautobot/project-static/docs/rest-api/authentication.html +1389 -190
- nautobot/project-static/docs/rest-api/filtering.html +1389 -190
- nautobot/project-static/docs/rest-api/overview.html +2002 -576
- nautobot/project-static/docs/rest-api/ui-related-endpoints.html +4057 -0
- nautobot/project-static/docs/search/search_index.json +1 -1
- nautobot/project-static/docs/sitemap.xml +197 -187
- nautobot/project-static/docs/sitemap.xml.gz +0 -0
- nautobot/project-static/docs/user-guides/custom-fields.html +1390 -191
- nautobot/project-static/docs/user-guides/getting-started/creating-devices.html +1392 -193
- nautobot/project-static/docs/user-guides/getting-started/index.html +1388 -189
- nautobot/project-static/docs/user-guides/getting-started/interfaces.html +1388 -189
- nautobot/project-static/docs/user-guides/getting-started/ipam.html +1386 -187
- nautobot/project-static/docs/user-guides/getting-started/platforms.html +1448 -249
- nautobot/project-static/docs/user-guides/getting-started/regions.html +1411 -212
- nautobot/project-static/docs/user-guides/getting-started/search-bar.html +1395 -196
- nautobot/project-static/docs/user-guides/getting-started/tenants.html +1448 -249
- nautobot/project-static/docs/user-guides/getting-started/vlans-and-vlan-groups.html +1448 -249
- nautobot/project-static/docs/user-guides/git-data-source.html +1405 -206
- nautobot/project-static/docs/user-guides/graphql.html +1402 -203
- nautobot/project-static/docs/user-guides/relationships.html +1448 -249
- nautobot/project-static/docs/user-guides/s3-django-storage.html +1448 -249
- nautobot/project-static/js/forms.js +16 -9
- nautobot/project-static/js/theme.js +5 -0
- nautobot/tenancy/api/serializers.py +4 -34
- nautobot/tenancy/api/urls.py +1 -1
- nautobot/tenancy/filters/__init__.py +9 -7
- nautobot/tenancy/filters/mixins.py +3 -2
- nautobot/tenancy/forms.py +3 -36
- nautobot/tenancy/migrations/0001_initial.py +0 -1
- nautobot/tenancy/migrations/0002_auto_slug.py +0 -1
- nautobot/tenancy/migrations/0003_mptt_to_tree_queries.py +0 -1
- nautobot/tenancy/migrations/0004_change_tree_manager_on_tree_models.py +0 -1
- nautobot/tenancy/migrations/0005_rename_foreign_keys_and_related_names.py +0 -1
- nautobot/tenancy/migrations/0006_created_datetime.py +0 -1
- nautobot/tenancy/migrations/0007_remove_tenant_tenantgroup_slug.py +20 -0
- nautobot/tenancy/migrations/0008_tagsfield.py +19 -0
- nautobot/tenancy/models.py +0 -30
- nautobot/tenancy/navigation.py +6 -39
- nautobot/tenancy/tables.py +4 -4
- nautobot/tenancy/templates/tenancy/tenant.html +12 -12
- nautobot/tenancy/templates/tenancy/tenant_edit.html +0 -1
- nautobot/tenancy/templates/tenancy/tenantgroup.html +1 -1
- nautobot/tenancy/tests/test_api.py +1 -12
- nautobot/tenancy/tests/test_filters.py +20 -12
- nautobot/tenancy/tests/test_views.py +11 -29
- nautobot/tenancy/urls.py +10 -10
- nautobot/tenancy/views.py +0 -3
- nautobot/ui/.eslintignore +6 -0
- nautobot/ui/.gitignore +10 -0
- nautobot/ui/.prettierignore +9 -0
- nautobot/ui/.prettierrc +4 -0
- nautobot/ui/README.md +33 -0
- nautobot/ui/app_imports.js.j2 +7 -0
- nautobot/ui/craco.config.js +46 -0
- nautobot/ui/jsconfig-base.json +11 -0
- nautobot/ui/jsconfig.json +5 -0
- nautobot/ui/lib/nautobot-craco-alias-plugin.js +40 -0
- nautobot/ui/package-lock.json +21451 -0
- nautobot/ui/package.json +70 -0
- nautobot/ui/public/index.html +47 -0
- nautobot/ui/public/logo192.png +0 -0
- nautobot/ui/public/logo512.png +0 -0
- nautobot/ui/public/manifest.json +25 -0
- nautobot/ui/public/nautobot_logo.svg +131 -0
- nautobot/ui/public/robots.txt +3 -0
- nautobot/ui/src/App.js +71 -0
- nautobot/ui/src/components/AppFullWidthComponents.js +8 -0
- nautobot/ui/src/components/AppTab.js +40 -0
- nautobot/ui/src/components/Apps.js +60 -0
- nautobot/ui/src/components/HomeChangelogPanel.js +98 -0
- nautobot/ui/src/components/HomePanel.js +58 -0
- nautobot/ui/src/components/JobHistoryTable.js +78 -0
- nautobot/ui/src/components/Layout.js +53 -0
- nautobot/ui/src/components/LoadingWidget.js +25 -0
- nautobot/ui/src/components/Navbar.js +116 -0
- nautobot/ui/src/components/NotificationPopover.js +27 -0
- nautobot/ui/src/components/ObjectListTable.js +209 -0
- nautobot/ui/src/components/ReferenceDataTag.js +35 -0
- nautobot/ui/src/components/RouterButton.js +10 -0
- nautobot/ui/src/components/RouterLink.js +10 -0
- nautobot/ui/src/components/SidebarNav.js +147 -0
- nautobot/ui/src/components/Table.js +48 -0
- nautobot/ui/src/components/TableItem.js +71 -0
- nautobot/ui/src/components/__tests__/AppFullWidthComponents.test.js +16 -0
- nautobot/ui/src/components/__tests__/AppTab.test.js +21 -0
- nautobot/ui/src/components/__tests__/Apps.test.js +14 -0
- nautobot/ui/src/components/__tests__/Layout.test.js +33 -0
- nautobot/ui/src/components/__tests__/Table.test.js +36 -0
- nautobot/ui/src/components/__tests__/TableItem.test.js +37 -0
- nautobot/ui/src/components/__tests__/paginator.test.js +43 -0
- nautobot/ui/src/components/__tests__/paginator_form.test.js +13 -0
- nautobot/ui/src/components/pagination.js +93 -0
- nautobot/ui/src/components/paginator.js +79 -0
- nautobot/ui/src/components/paginator_form.js +43 -0
- nautobot/ui/src/components/usePagination.js +57 -0
- nautobot/ui/src/constants/apiPath.js +10 -0
- nautobot/ui/src/constants/icons.js +15 -0
- nautobot/ui/src/constants/size.js +15 -0
- nautobot/ui/src/index.js +65 -0
- nautobot/ui/src/reportWebVitals.js +15 -0
- nautobot/ui/src/router.js +77 -0
- nautobot/ui/src/utils/api.js +131 -0
- nautobot/ui/src/utils/app-import.js +15 -0
- nautobot/ui/src/utils/color.js +15 -0
- nautobot/ui/src/utils/date.js +14 -0
- nautobot/ui/src/utils/index.js +15 -0
- nautobot/ui/src/utils/navigation.js +32 -0
- nautobot/ui/src/utils/session.js +64 -0
- nautobot/ui/src/utils/store.js +242 -0
- nautobot/ui/src/utils/string.js +6 -0
- nautobot/ui/src/utils/url.js +4 -0
- nautobot/ui/src/views/Home.js +138 -0
- nautobot/ui/src/views/InstalledApps.js +80 -0
- nautobot/ui/src/views/Login.js +48 -0
- nautobot/ui/src/views/Logout.js +20 -0
- nautobot/ui/src/views/__tests__/BSCreateViewTemplate.test.js +11 -0
- nautobot/ui/src/views/__tests__/BSListViewTemplate.test.js +107 -0
- nautobot/ui/src/views/__tests__/Login.test.js +15 -0
- nautobot/ui/src/views/generic/GenericView.js +142 -0
- nautobot/ui/src/views/generic/ObjectCreate.js +96 -0
- nautobot/ui/src/views/generic/ObjectList.js +127 -0
- nautobot/ui/src/views/generic/ObjectRetrieve.js +551 -0
- nautobot/users/admin.py +1 -1
- nautobot/users/api/serializers.py +51 -61
- nautobot/users/api/urls.py +1 -1
- nautobot/users/api/views.py +53 -2
- nautobot/users/migrations/0001_initial.py +0 -1
- nautobot/users/migrations/0002_token_ordering_by_created.py +0 -1
- nautobot/users/migrations/0003_alter_user_options.py +0 -1
- nautobot/users/migrations/0004_alter_user_managers.py +0 -1
- nautobot/users/tests/test_api.py +109 -28
- nautobot/users/tests/test_filters.py +0 -4
- nautobot/users/tests/test_models.py +0 -1
- nautobot/users/views.py +0 -7
- nautobot/virtualization/api/serializers.py +18 -132
- nautobot/virtualization/api/urls.py +1 -1
- nautobot/virtualization/api/views.py +1 -22
- nautobot/virtualization/choices.py +0 -2
- nautobot/virtualization/filters.py +12 -7
- nautobot/virtualization/forms.py +21 -117
- nautobot/virtualization/migrations/0001_initial.py +0 -1
- nautobot/virtualization/migrations/0002_virtualmachine_local_context_schema.py +0 -1
- nautobot/virtualization/migrations/0003_vminterface_verbose_name.py +0 -1
- nautobot/virtualization/migrations/0004_auto_slug.py +0 -1
- nautobot/virtualization/migrations/0005_add_natural_indexing.py +0 -1
- nautobot/virtualization/migrations/0006_vminterface_status.py +0 -1
- nautobot/virtualization/migrations/0007_vminterface_status_data_migration.py +0 -1
- nautobot/virtualization/migrations/0008_vminterface_parent.py +0 -1
- nautobot/virtualization/migrations/0009_cluster_location.py +0 -1
- nautobot/virtualization/migrations/0010_vminterface_mac_address_data_migration.py +0 -1
- nautobot/virtualization/migrations/0011_alter_vminterface_mac_address.py +0 -1
- nautobot/virtualization/migrations/0012_alter_virtualmachine_role_add_new_role.py +1 -2
- nautobot/virtualization/migrations/0013_migrate_virtualmachine_role_data.py +18 -12
- nautobot/virtualization/migrations/0014_rename_virtualmachine_roles.py +0 -1
- nautobot/virtualization/migrations/0015_rename_foreignkey_fields.py +1 -2
- nautobot/virtualization/migrations/0016_remove_site_foreign_key_from_cluster_class.py +0 -1
- nautobot/virtualization/migrations/0017_created_datetime.py +0 -1
- nautobot/virtualization/migrations/0018_related_name_changes.py +1 -2
- nautobot/virtualization/migrations/0019_vminterface_ip_addresses_m2m.py +0 -1
- nautobot/virtualization/migrations/0020_remove_clustergroup_clustertype_slug.py +20 -0
- nautobot/virtualization/migrations/0021_tagsfield_and_vminterface_to_primarymodel.py +39 -0
- nautobot/virtualization/migrations/0022_vminterface_timestamps_data_migration.py +17 -0
- nautobot/virtualization/migrations/0023_ipam__namespaces.py +25 -0
- nautobot/virtualization/migrations/0024_fixup_null_statuses.py +25 -0
- nautobot/virtualization/migrations/0025_status_nonnullable.py +29 -0
- nautobot/virtualization/models.py +39 -131
- nautobot/virtualization/navigation.py +18 -99
- nautobot/virtualization/tables.py +4 -4
- nautobot/virtualization/templates/virtualization/virtualmachine.html +13 -2
- nautobot/virtualization/templates/virtualization/virtualmachine_edit.html +6 -0
- nautobot/virtualization/tests/test_api.py +42 -52
- nautobot/virtualization/tests/test_filters.py +98 -75
- nautobot/virtualization/tests/test_models.py +36 -13
- nautobot/virtualization/tests/test_views.py +68 -73
- nautobot/virtualization/urls.py +10 -10
- nautobot/virtualization/views.py +8 -14
- {nautobot-2.0.0a2.dist-info → nautobot-2.0.0b1.dist-info}/METADATA +15 -22
- {nautobot-2.0.0a2.dist-info → nautobot-2.0.0b1.dist-info}/RECORD +987 -834
- {nautobot-2.0.0a2.dist-info → nautobot-2.0.0b1.dist-info}/WHEEL +1 -1
- nautobot/circuits/api/nested_serializers.py +0 -69
- nautobot/core/templates/plugin_template/navigation.py-tpl +0 -22
- nautobot/dcim/api/nested_serializers.py +0 -356
- nautobot/dcim/templates/dcim/device_import.html +0 -5
- nautobot/dcim/templates/dcim/device_import_child.html +0 -5
- nautobot/dcim/templates/dcim/inc/device_import_header.html +0 -4
- nautobot/extras/api/nested_serializers.py +0 -353
- nautobot/extras/migrations/0064_configcontext_data_migrations.py +0 -42
- nautobot/extras/migrations/0071_job__unique_name_data_migration.py +0 -47
- nautobot/extras/reports.py +0 -60
- nautobot/extras/scripts.py +0 -72
- nautobot/extras/tests/example_jobs/script_variables.py +0 -67
- nautobot/extras/tests/example_jobs/test_duplicate_name2.py +0 -5
- nautobot/extras/tests/example_jobs/test_fail.py +0 -16
- nautobot/extras/tests/example_jobs/test_file_upload_pass.py +0 -20
- nautobot/extras/tests/example_jobs/test_ipaddress_vars.py +0 -52
- nautobot/extras/tests/example_jobs/test_job_button_receiver.py +0 -21
- nautobot/extras/tests/example_jobs/test_job_hook_receiver.py +0 -20
- nautobot/extras/tests/example_jobs/test_location_with_custom_field.py +0 -35
- nautobot/extras/tests/example_jobs/test_log_redaction.py +0 -14
- nautobot/extras/tests/example_jobs/test_modify_db.py +0 -19
- nautobot/extras/tests/example_jobs/test_object_var_optional.py +0 -14
- nautobot/extras/tests/example_jobs/test_object_var_required.py +0 -14
- nautobot/extras/tests/example_jobs/test_object_vars.py +0 -29
- nautobot/extras/tests/example_jobs/test_pass.py +0 -19
- nautobot/extras/tests/example_jobs/test_read_only_fail.py +0 -24
- nautobot/extras/tests/example_jobs/test_read_only_no_commit_field.py +0 -10
- nautobot/extras/tests/example_jobs/test_read_only_pass.py +0 -22
- nautobot/ipam/api/nested_serializers.py +0 -143
- nautobot/project-static/docs/assets/javascripts/bundle.5a2dcb6a.min.js +0 -29
- nautobot/project-static/docs/assets/javascripts/bundle.5a2dcb6a.min.js.map +0 -8
- nautobot/project-static/docs/assets/javascripts/extra/bundle.5f09fbc3.min.js +0 -18
- nautobot/project-static/docs/assets/javascripts/extra/bundle.5f09fbc3.min.js.map +0 -8
- nautobot/project-static/docs/assets/stylesheets/extra.0d2c79a8.min.css +0 -1
- nautobot/project-static/docs/assets/stylesheets/extra.0d2c79a8.min.css.map +0 -1
- nautobot/project-static/docs/assets/stylesheets/main.975780f9.min.css +0 -1
- nautobot/project-static/docs/assets/stylesheets/main.975780f9.min.css.map +0 -1
- nautobot/project-static/docs/assets/stylesheets/palette.2505c338.min.css +0 -1
- nautobot/project-static/docs/assets/stylesheets/palette.2505c338.min.css.map +0 -1
- nautobot/tenancy/api/nested_serializers.py +0 -31
- nautobot/users/api/nested_serializers.py +0 -67
- nautobot/virtualization/api/nested_serializers.py +0 -65
- /nautobot/extras/{tests/example_jobs → test_jobs}/__init__.py +0 -0
- /nautobot/{dcim/models/sites.py → ipam/management/__init__.py} +0 -0
- {nautobot-2.0.0a2.dist-info → nautobot-2.0.0b1.dist-info}/LICENSE.txt +0 -0
- {nautobot-2.0.0a2.dist-info → nautobot-2.0.0b1.dist-info}/entry_points.txt +0 -0
|
@@ -87,7 +87,7 @@ class ChangeLogViewTest(ModelViewTestCase):
|
|
|
87
87
|
location = Location(
|
|
88
88
|
name="Test Location 1",
|
|
89
89
|
slug="test-location-1",
|
|
90
|
-
status=
|
|
90
|
+
status=self.location_status,
|
|
91
91
|
location_type=self.location_type,
|
|
92
92
|
)
|
|
93
93
|
location.save()
|
|
@@ -97,7 +97,7 @@ class ChangeLogViewTest(ModelViewTestCase):
|
|
|
97
97
|
"location_type": self.location_type.pk,
|
|
98
98
|
"name": "Test Location X",
|
|
99
99
|
"slug": "test-location-x",
|
|
100
|
-
"status":
|
|
100
|
+
"status": self.location_status.pk,
|
|
101
101
|
"cf_my_field": "DEF",
|
|
102
102
|
"cf_my_field_select": "Foo",
|
|
103
103
|
"tags": [self.tags[2].pk],
|
|
@@ -135,6 +135,7 @@ class ChangeLogViewTest(ModelViewTestCase):
|
|
|
135
135
|
name="Test Location 1",
|
|
136
136
|
slug="test-location-1",
|
|
137
137
|
location_type=self.location_type,
|
|
138
|
+
status=self.location_status,
|
|
138
139
|
_custom_field_data={"my_field": "ABC", "my_field_select": "Bar"},
|
|
139
140
|
)
|
|
140
141
|
location.save()
|
|
@@ -161,7 +162,7 @@ class ChangeLogViewTest(ModelViewTestCase):
|
|
|
161
162
|
form_data = {
|
|
162
163
|
"name": "Test Location 1",
|
|
163
164
|
"slug": "test-location-1",
|
|
164
|
-
"status": Status.objects.
|
|
165
|
+
"status": Status.objects.get_for_model(Location).first().pk,
|
|
165
166
|
"location_type": self.location_type.pk,
|
|
166
167
|
}
|
|
167
168
|
|
|
@@ -262,7 +263,7 @@ class ChangeLogAPITest(APITestCase):
|
|
|
262
263
|
data = {
|
|
263
264
|
"name": "Test Location 1",
|
|
264
265
|
"slug": "test-location-1",
|
|
265
|
-
"status": self.statuses.
|
|
266
|
+
"status": self.statuses[0].pk,
|
|
266
267
|
"location_type": f"{location_type.pk}",
|
|
267
268
|
"custom_fields": {
|
|
268
269
|
"my_field": "ABC",
|
|
@@ -294,14 +295,14 @@ class ChangeLogAPITest(APITestCase):
|
|
|
294
295
|
location = Location.objects.create(
|
|
295
296
|
name="Test Location 1",
|
|
296
297
|
slug="test-location-1",
|
|
297
|
-
status=self.statuses
|
|
298
|
+
status=self.statuses[1],
|
|
298
299
|
location_type=location_type,
|
|
299
300
|
)
|
|
300
301
|
|
|
301
302
|
data = {
|
|
302
303
|
"name": "Test Location X",
|
|
303
304
|
"slug": "test-location-x",
|
|
304
|
-
"status": self.statuses.
|
|
305
|
+
"status": self.statuses[0].pk,
|
|
305
306
|
"location_type": f"{location_type.pk}",
|
|
306
307
|
"custom_fields": {
|
|
307
308
|
"my_field": "DEF",
|
|
@@ -331,7 +332,7 @@ class ChangeLogAPITest(APITestCase):
|
|
|
331
332
|
name="Test Location 1",
|
|
332
333
|
slug="test-location-1",
|
|
333
334
|
location_type=location_type,
|
|
334
|
-
status=self.statuses
|
|
335
|
+
status=self.statuses[1],
|
|
335
336
|
_custom_field_data={
|
|
336
337
|
"my_field": "DEF",
|
|
337
338
|
"my_field_select": "Foo",
|
|
@@ -368,7 +369,7 @@ class ChangeLogAPITest(APITestCase):
|
|
|
368
369
|
name="Test Location 1",
|
|
369
370
|
slug="test-location-1",
|
|
370
371
|
location_type=location_type,
|
|
371
|
-
status=self.statuses
|
|
372
|
+
status=self.statuses[0],
|
|
372
373
|
_custom_field_data={"my_field": "ABC", "my_field_select": "Bar"},
|
|
373
374
|
)
|
|
374
375
|
location.save()
|
|
@@ -398,7 +399,7 @@ class ChangeLogAPITest(APITestCase):
|
|
|
398
399
|
location_payload = {
|
|
399
400
|
"name": "Test Location 1",
|
|
400
401
|
"slug": "test-location-1",
|
|
401
|
-
"status": self.statuses.
|
|
402
|
+
"status": self.statuses[0].pk,
|
|
402
403
|
"location_type": location_type.pk,
|
|
403
404
|
}
|
|
404
405
|
self.add_permissions("dcim.add_location")
|
|
@@ -418,7 +419,7 @@ class ChangeLogAPITest(APITestCase):
|
|
|
418
419
|
location_payload = {
|
|
419
420
|
"name": "Test Location 2",
|
|
420
421
|
"slug": "test-location-2",
|
|
421
|
-
"status": self.statuses.
|
|
422
|
+
"status": self.statuses[0].pk,
|
|
422
423
|
"location_type": location_type.pk,
|
|
423
424
|
}
|
|
424
425
|
self.add_permissions("dcim.add_location")
|
|
@@ -440,7 +441,7 @@ class ChangeLogAPITest(APITestCase):
|
|
|
440
441
|
location_payload = {
|
|
441
442
|
"name": "Test Location 1",
|
|
442
443
|
"slug": "test-location-1",
|
|
443
|
-
"status": self.statuses.
|
|
444
|
+
"status": self.statuses[0].pk,
|
|
444
445
|
"location_type": location_type.pk,
|
|
445
446
|
}
|
|
446
447
|
self.add_permissions("dcim.add_location")
|
|
@@ -461,7 +462,7 @@ class ChangeLogAPITest(APITestCase):
|
|
|
461
462
|
location_payload = {
|
|
462
463
|
"name": "Test Location 1",
|
|
463
464
|
"slug": "test-location-1",
|
|
464
|
-
"status": self.statuses.
|
|
465
|
+
"status": self.statuses[0].pk,
|
|
465
466
|
"location_type": location_type.pk,
|
|
466
467
|
}
|
|
467
468
|
self.assertEqual(ObjectChange.objects.count(), 0)
|
|
@@ -479,23 +480,23 @@ class ChangeLogAPITest(APITestCase):
|
|
|
479
480
|
|
|
480
481
|
def test_m2m_change(self):
|
|
481
482
|
"""Test that ManyToMany change only generates a single ObjectChange instance"""
|
|
482
|
-
cluster_type = ClusterType.objects.create(name="
|
|
483
|
+
cluster_type = ClusterType.objects.create(name="Test Cluster Type")
|
|
483
484
|
cluster = Cluster.objects.create(name="test_cluster", cluster_type=cluster_type)
|
|
484
485
|
vm_statuses = Status.objects.get_for_model(VirtualMachine)
|
|
485
486
|
vm = VirtualMachine.objects.create(
|
|
486
487
|
name="test_vm",
|
|
487
488
|
cluster=cluster,
|
|
488
|
-
status=vm_statuses
|
|
489
|
+
status=vm_statuses[0],
|
|
489
490
|
)
|
|
490
491
|
vminterface_statuses = Status.objects.get_for_model(VirtualMachine)
|
|
491
492
|
vm_interface = VMInterface.objects.create(
|
|
492
493
|
name="vm interface 1",
|
|
493
494
|
virtual_machine=vm,
|
|
494
|
-
status=vminterface_statuses
|
|
495
|
+
status=vminterface_statuses[0],
|
|
495
496
|
mode=InterfaceModeChoices.MODE_TAGGED,
|
|
496
497
|
)
|
|
497
498
|
vlan_statuses = Status.objects.get_for_model(VLAN)
|
|
498
|
-
tagged_vlan = VLAN.objects.create(vid=100, name="Vlan100", status=vlan_statuses
|
|
499
|
+
tagged_vlan = VLAN.objects.create(vid=100, name="Vlan100", status=vlan_statuses[0])
|
|
499
500
|
|
|
500
501
|
payload = {"tagged_vlans": [str(tagged_vlan.pk)], "description": "test vm interface m2m change"}
|
|
501
502
|
self.assertEqual(ObjectChange.objects.count(), 0)
|
|
@@ -7,7 +7,7 @@ from nautobot.core.utils.lookup import get_changes_for_model
|
|
|
7
7
|
from nautobot.dcim.models import Location, LocationType
|
|
8
8
|
from nautobot.extras.choices import ObjectChangeActionChoices, ObjectChangeEventContextChoices
|
|
9
9
|
from nautobot.extras.context_managers import web_request_context
|
|
10
|
-
from nautobot.extras.models import Webhook
|
|
10
|
+
from nautobot.extras.models import Status, Webhook
|
|
11
11
|
|
|
12
12
|
|
|
13
13
|
# Use the proper swappable User model
|
|
@@ -38,16 +38,15 @@ class WebRequestContextTestCase(TestCase):
|
|
|
38
38
|
app.control.purge() # Begin each test with an empty queue
|
|
39
39
|
|
|
40
40
|
def test_user_object_type_error(self):
|
|
41
|
-
|
|
42
41
|
with self.assertRaises(TypeError):
|
|
43
42
|
with web_request_context("a string is not a user object"):
|
|
44
43
|
pass
|
|
45
44
|
|
|
46
45
|
def test_change_log_created(self):
|
|
47
|
-
|
|
48
46
|
with web_request_context(self.user):
|
|
49
47
|
location_type = LocationType.objects.get(name="Campus")
|
|
50
|
-
|
|
48
|
+
location_status = Status.objects.get_for_model(Location).first()
|
|
49
|
+
location = Location(name="Test Location 1", location_type=location_type, status=location_status)
|
|
51
50
|
location.save()
|
|
52
51
|
|
|
53
52
|
location = Location.objects.get(name="Test Location 1")
|
|
@@ -57,10 +56,10 @@ class WebRequestContextTestCase(TestCase):
|
|
|
57
56
|
self.assertEqual(oc_list[0].action, ObjectChangeActionChoices.ACTION_CREATE)
|
|
58
57
|
|
|
59
58
|
def test_change_log_context(self):
|
|
60
|
-
|
|
61
59
|
with web_request_context(self.user, context_detail="test_change_log_context"):
|
|
62
60
|
location_type = LocationType.objects.get(name="Campus")
|
|
63
|
-
|
|
61
|
+
location_status = Status.objects.get_for_model(Location).first()
|
|
62
|
+
location = Location(name="Test Location 1", location_type=location_type, status=location_status)
|
|
64
63
|
location.save()
|
|
65
64
|
|
|
66
65
|
location = Location.objects.get(name="Test Location 1")
|
|
@@ -13,7 +13,6 @@ from nautobot.core.testing import APITestCase, TestCase, TransactionTestCase
|
|
|
13
13
|
from nautobot.core.testing.models import ModelTestCases
|
|
14
14
|
from nautobot.core.testing.utils import post_data
|
|
15
15
|
from nautobot.dcim.filters import LocationFilterSet
|
|
16
|
-
from nautobot.dcim.forms import LocationCSVForm
|
|
17
16
|
from nautobot.dcim.models import Device, Location, LocationType, Rack
|
|
18
17
|
from nautobot.dcim.tables import LocationTable
|
|
19
18
|
from nautobot.extras.choices import CustomFieldTypeChoices, CustomFieldFilterLogicChoices
|
|
@@ -25,11 +24,11 @@ from nautobot.virtualization.models import VirtualMachine
|
|
|
25
24
|
class CustomFieldTest(TestCase): # TODO: change to BaseModelTestCase once we have some baseline custom-field records
|
|
26
25
|
def setUp(self):
|
|
27
26
|
super().setUp()
|
|
28
|
-
|
|
27
|
+
location_status = Status.objects.get_for_model(Location).first()
|
|
29
28
|
lt = LocationType.objects.get(name="Campus")
|
|
30
|
-
Location.objects.create(name="Location A", slug="location-a", status=
|
|
31
|
-
Location.objects.create(name="Location B", slug="location-b", status=
|
|
32
|
-
Location.objects.create(name="Location C", slug="location-c", status=
|
|
29
|
+
Location.objects.create(name="Location A", slug="location-a", status=location_status, location_type=lt)
|
|
30
|
+
Location.objects.create(name="Location B", slug="location-b", status=location_status, location_type=lt)
|
|
31
|
+
Location.objects.create(name="Location C", slug="location-c", status=location_status, location_type=lt)
|
|
33
32
|
|
|
34
33
|
def test_immutable_fields(self):
|
|
35
34
|
"""Some fields may not be changed once set, due to the potential for complex downstream effects."""
|
|
@@ -446,12 +445,8 @@ class CustomFieldDataAPITest(APITestCase):
|
|
|
446
445
|
# Create some locations
|
|
447
446
|
cls.lt = LocationType.objects.get(name="Campus")
|
|
448
447
|
cls.locations = (
|
|
449
|
-
Location.objects.create(
|
|
450
|
-
|
|
451
|
-
),
|
|
452
|
-
Location.objects.create(
|
|
453
|
-
name="Location 2", slug="location-2", status=cls.statuses.get(slug="active"), location_type=cls.lt
|
|
454
|
-
),
|
|
448
|
+
Location.objects.create(name="Location 1", slug="location-1", status=cls.statuses[0], location_type=cls.lt),
|
|
449
|
+
Location.objects.create(name="Location 2", slug="location-2", status=cls.statuses[0], location_type=cls.lt),
|
|
455
450
|
)
|
|
456
451
|
|
|
457
452
|
# Assign custom field values for location 2
|
|
@@ -518,7 +513,7 @@ class CustomFieldDataAPITest(APITestCase):
|
|
|
518
513
|
"name": "Location 3",
|
|
519
514
|
"slug": "location-3",
|
|
520
515
|
"location_type": self.lt.pk,
|
|
521
|
-
"status": self.statuses.
|
|
516
|
+
"status": self.statuses[0].pk,
|
|
522
517
|
}
|
|
523
518
|
url = reverse("dcim-api:location-list")
|
|
524
519
|
self.add_permissions("dcim.add_location")
|
|
@@ -557,7 +552,7 @@ class CustomFieldDataAPITest(APITestCase):
|
|
|
557
552
|
data = {
|
|
558
553
|
"name": "Location 3",
|
|
559
554
|
"slug": "location-3",
|
|
560
|
-
"status": self.statuses.
|
|
555
|
+
"status": self.statuses[0].pk,
|
|
561
556
|
"location_type": self.lt.pk,
|
|
562
557
|
"custom_fields": {
|
|
563
558
|
"text_cf": "bar",
|
|
@@ -616,19 +611,19 @@ class CustomFieldDataAPITest(APITestCase):
|
|
|
616
611
|
"name": "Location 3",
|
|
617
612
|
"slug": "location-3",
|
|
618
613
|
"location_type": self.lt.pk,
|
|
619
|
-
"status": self.statuses.
|
|
614
|
+
"status": self.statuses[0].pk,
|
|
620
615
|
},
|
|
621
616
|
{
|
|
622
617
|
"name": "Location 4",
|
|
623
618
|
"slug": "location-4",
|
|
624
619
|
"location_type": self.lt.pk,
|
|
625
|
-
"status": self.statuses.
|
|
620
|
+
"status": self.statuses[0].pk,
|
|
626
621
|
},
|
|
627
622
|
{
|
|
628
623
|
"name": "Location 5",
|
|
629
624
|
"slug": "location-5",
|
|
630
625
|
"location_type": self.lt.pk,
|
|
631
|
-
"status": self.statuses.
|
|
626
|
+
"status": self.statuses[0].pk,
|
|
632
627
|
},
|
|
633
628
|
)
|
|
634
629
|
url = reverse("dcim-api:location-list")
|
|
@@ -884,7 +879,7 @@ class CustomFieldDataAPITest(APITestCase):
|
|
|
884
879
|
data = {
|
|
885
880
|
"name": "Location 4",
|
|
886
881
|
"slug": "location-4",
|
|
887
|
-
"status": self.statuses.
|
|
882
|
+
"status": self.statuses[0].pk,
|
|
888
883
|
"location_type": self.lt.pk,
|
|
889
884
|
"custom_fields": {
|
|
890
885
|
"text_cf": ["I", "am", "a", "disallowed", "type"],
|
|
@@ -907,6 +902,61 @@ class CustomFieldDataAPITest(APITestCase):
|
|
|
907
902
|
self.assertHttpStatus(response, status.HTTP_400_BAD_REQUEST)
|
|
908
903
|
self.assertIn("Value must be a string", str(response.content))
|
|
909
904
|
|
|
905
|
+
def test_create_without_required_field(self):
|
|
906
|
+
self.cf_text.default = None
|
|
907
|
+
self.cf_text.required = True
|
|
908
|
+
self.cf_text.save()
|
|
909
|
+
|
|
910
|
+
data = {
|
|
911
|
+
"name": "Location N",
|
|
912
|
+
"slug": "location-n",
|
|
913
|
+
"location_type": self.lt.pk,
|
|
914
|
+
"status": self.statuses[0].pk,
|
|
915
|
+
}
|
|
916
|
+
url = reverse("dcim-api:location-list")
|
|
917
|
+
self.add_permissions("dcim.add_location")
|
|
918
|
+
response = self.client.post(url, data, format="json", **self.header)
|
|
919
|
+
self.assertHttpStatus(response, status.HTTP_400_BAD_REQUEST)
|
|
920
|
+
self.assertIn("Required field cannot be empty", str(response.content))
|
|
921
|
+
|
|
922
|
+
# Try in CSV format too
|
|
923
|
+
csvdata = "\n".join(
|
|
924
|
+
[
|
|
925
|
+
"name,slug,location_type,status",
|
|
926
|
+
f"Location N,location-n,{self.lt.natural_key_slug},{self.statuses[0].name}",
|
|
927
|
+
]
|
|
928
|
+
)
|
|
929
|
+
response = self.client.post(url, csvdata, content_type="text/csv", **self.header)
|
|
930
|
+
self.assertHttpStatus(response, status.HTTP_400_BAD_REQUEST)
|
|
931
|
+
self.assertIn("Required field cannot be empty", str(response.content))
|
|
932
|
+
|
|
933
|
+
def test_create_invalid_select_choice(self):
|
|
934
|
+
data = {
|
|
935
|
+
"name": "Location N",
|
|
936
|
+
"slug": "location-n",
|
|
937
|
+
"location_type": self.lt.pk,
|
|
938
|
+
"status": self.statuses[0].pk,
|
|
939
|
+
"custom_fields": {
|
|
940
|
+
"choice_cf": "Frobozz",
|
|
941
|
+
},
|
|
942
|
+
}
|
|
943
|
+
url = reverse("dcim-api:location-list")
|
|
944
|
+
self.add_permissions("dcim.add_location")
|
|
945
|
+
response = self.client.post(url, data, format="json", **self.header)
|
|
946
|
+
self.assertHttpStatus(response, status.HTTP_400_BAD_REQUEST)
|
|
947
|
+
self.assertIn("Invalid choice", str(response.content))
|
|
948
|
+
|
|
949
|
+
# Try in CSV format too
|
|
950
|
+
csvdata = "\n".join(
|
|
951
|
+
[
|
|
952
|
+
"name,slug,location_type,status,cf_choice_cf",
|
|
953
|
+
f"Location N,location-n,{self.lt.natural_key_slug},{self.statuses[0].name},Frobozz",
|
|
954
|
+
]
|
|
955
|
+
)
|
|
956
|
+
response = self.client.post(url, csvdata, content_type="text/csv", **self.header)
|
|
957
|
+
self.assertHttpStatus(response, status.HTTP_400_BAD_REQUEST)
|
|
958
|
+
self.assertIn("Invalid choice", str(response.content))
|
|
959
|
+
|
|
910
960
|
|
|
911
961
|
class CustomFieldImportTest(TestCase):
|
|
912
962
|
"""
|
|
@@ -956,6 +1006,7 @@ class CustomFieldImportTest(TestCase):
|
|
|
956
1006
|
Import a Location in CSV format, including a value for each CustomField.
|
|
957
1007
|
"""
|
|
958
1008
|
LocationType.objects.create(name="Test Root")
|
|
1009
|
+
location_status = Status.objects.get_for_model(Location).first()
|
|
959
1010
|
data = (
|
|
960
1011
|
[
|
|
961
1012
|
"name",
|
|
@@ -974,7 +1025,7 @@ class CustomFieldImportTest(TestCase):
|
|
|
974
1025
|
"Location 1",
|
|
975
1026
|
"location-1",
|
|
976
1027
|
"Test Root",
|
|
977
|
-
|
|
1028
|
+
location_status.name,
|
|
978
1029
|
"ABC",
|
|
979
1030
|
"123",
|
|
980
1031
|
"True",
|
|
@@ -987,7 +1038,7 @@ class CustomFieldImportTest(TestCase):
|
|
|
987
1038
|
"Location 2",
|
|
988
1039
|
"location-2",
|
|
989
1040
|
"Test Root",
|
|
990
|
-
|
|
1041
|
+
location_status.name,
|
|
991
1042
|
"DEF",
|
|
992
1043
|
"456",
|
|
993
1044
|
"False",
|
|
@@ -996,7 +1047,7 @@ class CustomFieldImportTest(TestCase):
|
|
|
996
1047
|
"Choice B",
|
|
997
1048
|
'"Choice A,Choice B"',
|
|
998
1049
|
],
|
|
999
|
-
["Location 3", "location-3", "Test Root",
|
|
1050
|
+
["Location 3", "location-3", "Test Root", location_status.name, "", "", "", "", "", "", ""],
|
|
1000
1051
|
)
|
|
1001
1052
|
if "example_plugin" in settings.PLUGINS:
|
|
1002
1053
|
data[0].append("cf_example_plugin_auto_custom_field")
|
|
@@ -1008,7 +1059,10 @@ class CustomFieldImportTest(TestCase):
|
|
|
1008
1059
|
self.assertEqual(response.status_code, 200)
|
|
1009
1060
|
|
|
1010
1061
|
# Validate data for location 1
|
|
1011
|
-
|
|
1062
|
+
try:
|
|
1063
|
+
location1 = Location.objects.get(name="Location 1")
|
|
1064
|
+
except Location.DoesNotExist:
|
|
1065
|
+
self.fail(str(response.content))
|
|
1012
1066
|
if "example_plugin" in settings.PLUGINS:
|
|
1013
1067
|
self.assertEqual(len(location1.cf), 8)
|
|
1014
1068
|
else:
|
|
@@ -1043,34 +1097,6 @@ class CustomFieldImportTest(TestCase):
|
|
|
1043
1097
|
location3 = Location.objects.get(name="Location 3")
|
|
1044
1098
|
self.assertFalse(any(location3.cf.values()))
|
|
1045
1099
|
|
|
1046
|
-
def test_import_missing_required(self):
|
|
1047
|
-
"""
|
|
1048
|
-
Attempt to import an object missing a required custom field.
|
|
1049
|
-
"""
|
|
1050
|
-
# Set one of our CustomFields to required
|
|
1051
|
-
CustomField.objects.filter(label="Text").update(required=True)
|
|
1052
|
-
lt = LocationType.objects.get(name="Campus")
|
|
1053
|
-
form_data = {
|
|
1054
|
-
"name": "Location 1",
|
|
1055
|
-
"slug": "location-1",
|
|
1056
|
-
"location_type": lt.pk,
|
|
1057
|
-
}
|
|
1058
|
-
|
|
1059
|
-
form = LocationCSVForm(data=form_data)
|
|
1060
|
-
self.assertFalse(form.is_valid())
|
|
1061
|
-
self.assertIn("cf_text", form.errors)
|
|
1062
|
-
|
|
1063
|
-
def test_import_invalid_choice(self):
|
|
1064
|
-
"""
|
|
1065
|
-
Attempt to import an object with an invalid choice selection.
|
|
1066
|
-
"""
|
|
1067
|
-
lt = LocationType.objects.get(name="Campus")
|
|
1068
|
-
form_data = {"name": "Location 1", "slug": "location-1", "location_type": lt.name, "cf_select": "Choice X"}
|
|
1069
|
-
|
|
1070
|
-
form = LocationCSVForm(data=form_data)
|
|
1071
|
-
self.assertFalse(form.is_valid())
|
|
1072
|
-
self.assertIn("cf_select", form.errors)
|
|
1073
|
-
|
|
1074
1100
|
|
|
1075
1101
|
class CustomFieldModelTest(TestCase):
|
|
1076
1102
|
"""
|
|
@@ -1088,47 +1114,46 @@ class CustomFieldModelTest(TestCase):
|
|
|
1088
1114
|
cf2.content_types.set([ContentType.objects.get_for_model(Rack)])
|
|
1089
1115
|
cls.lt = LocationType.objects.get(name="Campus")
|
|
1090
1116
|
|
|
1091
|
-
|
|
1092
|
-
|
|
1093
|
-
|
|
1094
|
-
self.computed_field_one = ComputedField.objects.create(
|
|
1117
|
+
cls.location_status = Status.objects.get_for_model(Location).first()
|
|
1118
|
+
cls.location1 = Location.objects.create(name="NYC", location_type=cls.lt, status=cls.location_status)
|
|
1119
|
+
cls.computed_field_one = ComputedField.objects.create(
|
|
1095
1120
|
content_type=ContentType.objects.get_for_model(Location),
|
|
1096
|
-
|
|
1121
|
+
key="computed_field_one",
|
|
1097
1122
|
label="Computed Field One",
|
|
1098
1123
|
template="{{ obj.name }} is the name of this location.",
|
|
1099
1124
|
fallback_value="An error occurred while rendering this template.",
|
|
1100
1125
|
weight=100,
|
|
1101
1126
|
)
|
|
1102
1127
|
# Field whose template will raise a TemplateError
|
|
1103
|
-
|
|
1128
|
+
cls.bad_computed_field = ComputedField.objects.create(
|
|
1104
1129
|
content_type=ContentType.objects.get_for_model(Location),
|
|
1105
|
-
|
|
1130
|
+
key="bad_computed_field",
|
|
1106
1131
|
label="Bad Computed Field",
|
|
1107
1132
|
template="{{ something_that_throws_an_err | not_a_real_filter }} bad data",
|
|
1108
1133
|
fallback_value="This template has errored",
|
|
1109
1134
|
weight=100,
|
|
1110
1135
|
)
|
|
1111
1136
|
# Field whose template will raise a TypeError
|
|
1112
|
-
|
|
1137
|
+
cls.worse_computed_field = ComputedField.objects.create(
|
|
1113
1138
|
content_type=ContentType.objects.get_for_model(Location),
|
|
1114
|
-
|
|
1139
|
+
key="worse_computed_field",
|
|
1115
1140
|
label="Worse Computed Field",
|
|
1116
1141
|
template="{{ obj.images | list }}",
|
|
1117
1142
|
fallback_value="Another template error",
|
|
1118
1143
|
weight=200,
|
|
1119
1144
|
)
|
|
1120
|
-
|
|
1145
|
+
cls.non_location_computed_field = ComputedField.objects.create(
|
|
1121
1146
|
content_type=ContentType.objects.get_for_model(Device),
|
|
1122
|
-
|
|
1147
|
+
key="device_computed_field",
|
|
1123
1148
|
label="Device Computed Field",
|
|
1124
1149
|
template="Hello, world.",
|
|
1125
1150
|
fallback_value="This template has errored",
|
|
1126
1151
|
weight=100,
|
|
1127
1152
|
)
|
|
1128
1153
|
# Field whose template will return None, with fallback_value defaulting to empty string
|
|
1129
|
-
|
|
1154
|
+
cls.bad_attribute_computed_field = ComputedField.objects.create(
|
|
1130
1155
|
content_type=ContentType.objects.get_for_model(Location),
|
|
1131
|
-
|
|
1156
|
+
key="bad_attribute_computed_field",
|
|
1132
1157
|
label="Bad Attribute Computed Field",
|
|
1133
1158
|
template="{{ obj.location }}",
|
|
1134
1159
|
weight=200,
|
|
@@ -1140,7 +1165,7 @@ class CustomFieldModelTest(TestCase):
|
|
|
1140
1165
|
from the database.
|
|
1141
1166
|
"""
|
|
1142
1167
|
location = Location(
|
|
1143
|
-
name="Test Location", slug="test-location", status=self.
|
|
1168
|
+
name="Test Location", slug="test-location", status=self.location_status, location_type=self.lt
|
|
1144
1169
|
)
|
|
1145
1170
|
|
|
1146
1171
|
# Check custom field data on new instance
|
|
@@ -1219,7 +1244,7 @@ class CustomFieldModelTest(TestCase):
|
|
|
1219
1244
|
self.assertDictEqual(self.location1.get_computed_fields(label_as_key=True), expected_renderings)
|
|
1220
1245
|
|
|
1221
1246
|
def test_get_computed_fields_only_returns_fields_for_content_type(self):
|
|
1222
|
-
self.assertTrue(self.non_location_computed_field.
|
|
1247
|
+
self.assertTrue(self.non_location_computed_field.key not in self.location1.get_computed_fields())
|
|
1223
1248
|
|
|
1224
1249
|
def test_check_if_key_is_graphql_safe(self):
|
|
1225
1250
|
"""
|
|
@@ -1344,10 +1369,12 @@ class CustomFieldFilterTest(TestCase):
|
|
|
1344
1369
|
CustomFieldChoice.objects.create(custom_field=cf, value="Foo")
|
|
1345
1370
|
CustomFieldChoice.objects.create(custom_field=cf, value="Bar")
|
|
1346
1371
|
cls.location_type = LocationType.objects.get(name="Campus")
|
|
1372
|
+
location_status = Status.objects.get_for_model(Location).first()
|
|
1347
1373
|
Location.objects.create(
|
|
1348
1374
|
name="Location 1",
|
|
1349
1375
|
slug="location-1",
|
|
1350
1376
|
location_type=cls.location_type,
|
|
1377
|
+
status=location_status,
|
|
1351
1378
|
_custom_field_data={
|
|
1352
1379
|
"cf1": 100,
|
|
1353
1380
|
"cf2": True,
|
|
@@ -1364,6 +1391,7 @@ class CustomFieldFilterTest(TestCase):
|
|
|
1364
1391
|
name="Location 2",
|
|
1365
1392
|
slug="location-2",
|
|
1366
1393
|
location_type=cls.location_type,
|
|
1394
|
+
status=location_status,
|
|
1367
1395
|
_custom_field_data={
|
|
1368
1396
|
"cf1": 200,
|
|
1369
1397
|
"cf2": False,
|
|
@@ -1380,10 +1408,15 @@ class CustomFieldFilterTest(TestCase):
|
|
|
1380
1408
|
name="Location 3",
|
|
1381
1409
|
slug="location-3",
|
|
1382
1410
|
location_type=cls.location_type,
|
|
1411
|
+
status=location_status,
|
|
1383
1412
|
_custom_field_data={"cf9": ["Foo", "Bar"]},
|
|
1384
1413
|
)
|
|
1385
1414
|
Location.objects.create(
|
|
1386
|
-
name="Location 4",
|
|
1415
|
+
name="Location 4",
|
|
1416
|
+
slug="location-4",
|
|
1417
|
+
location_type=cls.location_type,
|
|
1418
|
+
status=location_status,
|
|
1419
|
+
_custom_field_data={},
|
|
1387
1420
|
)
|
|
1388
1421
|
|
|
1389
1422
|
def test_filter_integer(self):
|
|
@@ -1729,7 +1762,7 @@ class CustomFieldChoiceTest(ModelTestCases.BaseModelTestCase):
|
|
|
1729
1762
|
self.choice = CustomFieldChoice(custom_field=self.cf, value="Foo")
|
|
1730
1763
|
self.choice.save()
|
|
1731
1764
|
|
|
1732
|
-
|
|
1765
|
+
location_status = Status.objects.get_for_model(Location).first()
|
|
1733
1766
|
self.location_type = LocationType.objects.get(name="Campus")
|
|
1734
1767
|
self.location = Location(
|
|
1735
1768
|
name="Location 1",
|
|
@@ -1738,7 +1771,7 @@ class CustomFieldChoiceTest(ModelTestCases.BaseModelTestCase):
|
|
|
1738
1771
|
_custom_field_data={
|
|
1739
1772
|
"cf1": "Foo",
|
|
1740
1773
|
},
|
|
1741
|
-
status=
|
|
1774
|
+
status=location_status,
|
|
1742
1775
|
)
|
|
1743
1776
|
self.location.validated_save()
|
|
1744
1777
|
|
|
@@ -1806,7 +1839,8 @@ class CustomFieldChoiceTest(ModelTestCases.BaseModelTestCase):
|
|
|
1806
1839
|
class CustomFieldBackgroundTasks(TransactionTestCase):
|
|
1807
1840
|
def test_provision_field_task(self):
|
|
1808
1841
|
location_type = LocationType.objects.create(name="Root Type 1")
|
|
1809
|
-
|
|
1842
|
+
location_status = Status.objects.get_for_model(Location).first()
|
|
1843
|
+
location = Location(name="Location 1", slug="location-1", location_type=location_type, status=location_status)
|
|
1810
1844
|
location.save()
|
|
1811
1845
|
|
|
1812
1846
|
obj_type = ContentType.objects.get_for_model(Location)
|
|
@@ -1825,14 +1859,15 @@ class CustomFieldBackgroundTasks(TransactionTestCase):
|
|
|
1825
1859
|
type=CustomFieldTypeChoices.TYPE_TEXT,
|
|
1826
1860
|
)
|
|
1827
1861
|
cf.save()
|
|
1828
|
-
logging.disable(logging.ERROR)
|
|
1829
1862
|
cf.content_types.set([obj_type])
|
|
1830
1863
|
location_type = LocationType.objects.create(name="Root Type 2")
|
|
1864
|
+
location_status = Status.objects.get_for_model(Location).first()
|
|
1831
1865
|
location = Location(
|
|
1832
1866
|
name="Location 1",
|
|
1833
1867
|
slug="location-1",
|
|
1834
|
-
_custom_field_data={"cf1": "foo"},
|
|
1835
1868
|
location_type=location_type,
|
|
1869
|
+
status=location_status,
|
|
1870
|
+
_custom_field_data={"cf1": "foo"},
|
|
1836
1871
|
)
|
|
1837
1872
|
location.save()
|
|
1838
1873
|
|
|
@@ -1841,7 +1876,6 @@ class CustomFieldBackgroundTasks(TransactionTestCase):
|
|
|
1841
1876
|
location.refresh_from_db()
|
|
1842
1877
|
|
|
1843
1878
|
self.assertTrue("cf1" not in location.cf)
|
|
1844
|
-
logging.disable(logging.NOTSET)
|
|
1845
1879
|
|
|
1846
1880
|
def test_update_custom_field_choice_data_task(self):
|
|
1847
1881
|
obj_type = ContentType.objects.get_for_model(Location)
|
|
@@ -1855,8 +1889,13 @@ class CustomFieldBackgroundTasks(TransactionTestCase):
|
|
|
1855
1889
|
choice = CustomFieldChoice(custom_field=cf, value="Foo")
|
|
1856
1890
|
choice.save()
|
|
1857
1891
|
location_type = LocationType.objects.create(name="Root Type 3")
|
|
1892
|
+
location_status = Status.objects.get_for_model(Location).first()
|
|
1858
1893
|
location = Location(
|
|
1859
|
-
name="Location 1",
|
|
1894
|
+
name="Location 1",
|
|
1895
|
+
slug="location-1",
|
|
1896
|
+
location_type=location_type,
|
|
1897
|
+
status=location_status,
|
|
1898
|
+
_custom_field_data={"cf1": "Foo"},
|
|
1860
1899
|
)
|
|
1861
1900
|
location.save()
|
|
1862
1901
|
|
|
@@ -1944,7 +1983,7 @@ class CustomFieldTableTest(TestCase):
|
|
|
1944
1983
|
# Create a location
|
|
1945
1984
|
location_type = LocationType.objects.create(name="Root Type 4")
|
|
1946
1985
|
self.location = Location.objects.create(
|
|
1947
|
-
name="Location Custom", slug="location-1", status=statuses.
|
|
1986
|
+
name="Location Custom", slug="location-1", status=statuses.first(), location_type=location_type
|
|
1948
1987
|
)
|
|
1949
1988
|
|
|
1950
1989
|
# Assign custom field values for location 2
|