This is an automated email from the ASF dual-hosted git repository.

jscheffl pushed a commit to branch main
in repository https://gitbox.apache.org/repos/asf/airflow.git


The following commit(s) were added to refs/heads/main by this push:
     new bd2bb9096ad Move fab provider to new structure (#46144)
bd2bb9096ad is described below

commit bd2bb9096adc5489fa4b0234b5debb9f735cd41e
Author: Josix <[email protected]>
AuthorDate: Sat Feb 1 04:19:00 2025 +0800

    Move fab provider to new structure (#46144)
    
    * refactor(providers/fab): move fab provider to new structure
    
    * fix: updated changed path
    
    * refactor: Move FAB test views to provider-specific directory
    
    * fixup! refactor(providers/fab): move fab provider to new structure
    
    * fixup! refactor(providers/fab): move fab provider to new structure
    
    * fixup! refactor(providers/fab): move fab provider to new structure
    
    * fixup! refactor(providers/fab): move fab provider to new structure
---
 .github/boring-cyborg.yml                          |   4 +-
 .pre-commit-config.yaml                            |  12 +-
 docs/.gitignore                                    |   1 +
 docs/apache-airflow-providers-fab/changelog.rst    |  25 ---
 .../3rd-party-licenses/LICENSES-ui.txt             |   2 +-
 providers/fab/README.rst                           |  86 +++++++++
 .../fab/docs}/auth-manager/access-control.rst      |   8 +-
 .../fab/docs}/auth-manager/api-authentication.rst  |   0
 .../fab/docs}/auth-manager/index.rst               |   0
 .../auth-manager/webserver-authentication.rst      |   0
 .../fab/CHANGELOG.rst => fab/docs/changelog.rst}   |   0
 .../fab/docs}/cli-ref.rst                          |   0
 .../fab/docs}/commits.rst                          |   0
 .../fab/docs}/configurations-ref.rst               |   0
 .../fab/docs}/img/add-role.png                     | Bin
 ...am_fab_auth_manager_airflow_architecture.md5sum |   0
 ...agram_fab_auth_manager_airflow_architecture.png | Bin
 ...iagram_fab_auth_manager_airflow_architecture.py |   0
 .../fab/docs}/img/new-role.png                     | Bin
 .../fab/docs}/index.rst                            |   0
 .../docs}/installing-providers-from-sources.rst    |   0
 .../fab/docs}/migrations-ref.rst                   |   0
 .../fab/docs}/security.rst                         |   0
 .../fab/docs}/stable-rest-api-ref.rst              |   0
 .../fab/docs}/upgrading.rst                        |   0
 .../{src/airflow/providers => }/fab/provider.yaml  |  22 ---
 providers/fab/pyproject.toml                       | 102 +++++++++++
 providers/fab/src/airflow/providers/fab/LICENSE    | 201 +++++++++++++++++++++
 .../src/airflow/providers/fab/__init__.py          |   0
 .../src/airflow/providers/fab/alembic.ini          |   0
 .../airflow/providers/fab/auth_manager/__init__.py |   0
 .../providers/fab/auth_manager/api/__init__.py     |   0
 .../fab/auth_manager/api/auth/__init__.py          |   0
 .../fab/auth_manager/api/auth/backend/__init__.py  |   0
 .../auth_manager/api/auth/backend/basic_auth.py    |   0
 .../auth_manager/api/auth/backend/kerberos_auth.py |   0
 .../fab/auth_manager/api/auth/backend/session.py   |   0
 .../fab/auth_manager/api_endpoints/__init__.py     |   0
 .../api_endpoints/role_and_permission_endpoint.py  |   0
 .../auth_manager/api_endpoints/user_endpoint.py    |   0
 .../fab/auth_manager/cli_commands/__init__.py      |   0
 .../fab/auth_manager/cli_commands/db_command.py    |   0
 .../fab/auth_manager/cli_commands/definition.py    |   0
 .../fab/auth_manager/cli_commands/role_command.py  |   0
 .../auth_manager/cli_commands/sync_perm_command.py |   0
 .../fab/auth_manager/cli_commands/user_command.py  |   0
 .../fab/auth_manager/cli_commands/utils.py         |   0
 .../providers/fab/auth_manager/fab_auth_manager.py |  12 +-
 .../providers/fab/auth_manager/models/__init__.py  |   0
 .../fab/auth_manager/models/anonymous_user.py      |   0
 .../providers/fab/auth_manager/models/db.py        |   0
 .../providers/fab/auth_manager/openapi/__init__.py |   0
 .../providers/fab/auth_manager/openapi/v1.yaml     |   0
 .../providers/fab/auth_manager/schemas/__init__.py |   0
 .../schemas/role_and_permission_schema.py          |   0
 .../fab/auth_manager/schemas/user_schema.py        |   0
 .../fab/auth_manager/security_manager/__init__.py  |   0
 .../fab/auth_manager/security_manager/constants.py |   0
 .../fab/auth_manager/security_manager/override.py  |   0
 .../providers/fab/auth_manager/views/__init__.py   |   0
 .../fab/auth_manager/views/permissions.py          |   0
 .../providers/fab/auth_manager/views/roles_list.py |   0
 .../providers/fab/auth_manager/views/user.py       |   0
 .../providers/fab/auth_manager/views/user_edit.py  |   0
 .../providers/fab/auth_manager/views/user_stats.py |   0
 .../src/airflow/providers/fab/get_provider_info.py |  90 +++++++++
 .../src/airflow/providers/fab/migrations/README    |   0
 .../airflow/providers/fab/migrations/__init__.py   |   0
 .../src/airflow/providers/fab/migrations/env.py    |   0
 .../providers/fab/migrations/script.py.mako        |   0
 .../versions/0001_1_4_0_placeholder_migration.py   |   0
 .../providers/fab/migrations/versions/__init__.py  |   0
 .../src/airflow/providers/fab/www/__init__.py      |   0
 .../providers/fab/www/api_connexion/__init__.py    |   0
 .../providers/fab/www/api_connexion/exceptions.py  |   0
 .../providers/fab/www/api_connexion/parameters.py  |   0
 .../providers/fab/www/api_connexion/security.py    |   0
 .../providers/fab/www/api_connexion/types.py       |   0
 .../{ => fab}/src/airflow/providers/fab/www/app.py |   0
 .../src/airflow/providers/fab/www/constants.py     |   0
 .../providers/fab/www/extensions/__init__.py       |   0
 .../fab/www/extensions/init_appbuilder.py          |   0
 .../fab/www/extensions/init_jinja_globals.py       |   0
 .../fab/www/extensions/init_manifest_files.py      |   0
 .../providers/fab/www/extensions/init_security.py  |   0
 .../providers/fab/www/extensions/init_session.py   |   0
 .../providers/fab/www/extensions/init_views.py     |   0
 .../airflow/providers/fab/www/package-lock.json    |   0
 .../src/airflow/providers/fab/www/package.json     |   0
 .../airflow/providers/fab/www/security/__init__.py |   0
 .../providers/fab/www/security/permissions.py      |   0
 .../airflow/providers/fab/www/security_manager.py  |   0
 .../src/airflow/providers/fab/www/session.py       |   0
 .../fab/www/static/css/bootstrap-theme.css         |   0
 .../providers/fab/www/static/css/loading-dots.css  |   0
 .../airflow/providers/fab/www/static/css/main.css  |   0
 .../fab/www/static/css/material-icons.css          |   0
 .../providers/fab/www/static/js/datetime_utils.js  |   0
 .../airflow/providers/fab/www/static/js/main.js    |   0
 .../airflow/providers/fab/www/static/sort_asc.png  |   0
 .../airflow/providers/fab/www/static/sort_both.png | Bin
 .../airflow/providers/fab/www/static/sort_desc.png | Bin
 .../fab/www/templates/airflow/_messages.html       |   0
 .../providers/fab/www/templates/airflow/error.html |   0
 .../providers/fab/www/templates/airflow/main.html  |   0
 .../fab/www/templates/airflow/traceback.html       |   0
 .../fab/www/templates/appbuilder/index.html        |   0
 .../fab/www/templates/appbuilder/navbar.html       |   0
 .../fab/www/templates/appbuilder/navbar_menu.html  |   0
 .../fab/www/templates/appbuilder/navbar_right.html |   0
 .../src/airflow/providers/fab/www/utils.py         |   0
 .../src/airflow/providers/fab/www/views.py         |   0
 .../airflow/providers/fab/www/webpack.config.js    |   0
 .../views/user_stats.py => fab/tests/conftest.py}  |  21 +--
 .../tests/provider_tests}/__init__.py              |   2 +-
 .../tests/provider_tests}/fab/__init__.py          |   0
 .../provider_tests}/fab/auth_manager/__init__.py   |   0
 .../fab/auth_manager/api/__init__.py               |   0
 .../fab/auth_manager/api/auth/__init__.py          |   0
 .../fab/auth_manager/api/auth/backend/__init__.py  |   0
 .../api/auth/backend/test_basic_auth.py            |   0
 .../api/auth/backend/test_kerberos_auth.py         |   0
 .../auth_manager/api/auth/backend/test_session.py  |   0
 .../fab/auth_manager/api_endpoints/__init__.py     |   0
 .../api_endpoints/api_connexion_utils.py           |   0
 .../api_endpoints/remote_user_api_auth_backend.py  |   0
 .../api_endpoints/test_asset_endpoint.py           |   2 +-
 .../fab/auth_manager/api_endpoints/test_auth.py    |   0
 .../fab/auth_manager/api_endpoints/test_cors.py    |   0
 .../api_endpoints/test_dag_endpoint.py             |   2 +-
 .../api_endpoints/test_dag_run_endpoint.py         |   4 +-
 .../api_endpoints/test_dag_source_endpoint.py      |   2 +-
 .../api_endpoints/test_dag_warning_endpoint.py     |   2 +-
 .../api_endpoints/test_event_log_endpoint.py       |   2 +-
 .../api_endpoints/test_import_error_endpoint.py    |   2 +-
 .../test_role_and_permission_endpoint.py           |   4 +-
 .../api_endpoints/test_task_instance_endpoint.py   |   4 +-
 .../api_endpoints/test_user_endpoint.py            |   4 +-
 .../api_endpoints/test_variable_endpoint.py        |   2 +-
 .../api_endpoints/test_xcom_endpoint.py            |   2 +-
 .../fab/auth_manager/cli_commands/__init__.py      |   0
 .../auth_manager/cli_commands/test_db_command.py   |   0
 .../auth_manager/cli_commands/test_definition.py   |   0
 .../auth_manager/cli_commands/test_role_command.py |   0
 .../cli_commands/test_sync_perm_command.py         |   0
 .../auth_manager/cli_commands/test_user_command.py |   0
 .../fab/auth_manager/cli_commands/test_utils.py    |   0
 .../provider_tests}/fab/auth_manager/conftest.py   |   2 +-
 .../fab/auth_manager/models/__init__.py            |   0
 .../fab/auth_manager/models/test_anonymous_user.py |   0
 .../fab/auth_manager/models/test_db.py             |   9 +-
 .../fab/auth_manager/schemas/__init__.py           |   0
 .../schemas/test_role_and_permission_schema.py     |   3 +-
 .../fab/auth_manager/schemas/test_user_schema.py   |   2 +-
 .../fab/auth_manager/security_manager/__init__.py  |   0
 .../security_manager/test_constants.py             |   0
 .../auth_manager/security_manager/test_override.py |   0
 .../fab/auth_manager/test_fab_auth_manager.py      |   3 +-
 .../fab/auth_manager/test_models.py                |   0
 .../fab/auth_manager/test_security.py              |   4 +-
 .../fab/auth_manager/views/__init__.py             |   0
 .../fab/auth_manager/views/test_permissions.py     |   4 +-
 .../fab/auth_manager/views/test_roles_list.py      |   4 +-
 .../fab/auth_manager/views/test_user.py            |   4 +-
 .../fab/auth_manager/views/test_user_edit.py       |   4 +-
 .../fab/auth_manager/views/test_user_stats.py      |   4 +-
 .../tests/provider_tests/fab/www}/__init__.py      |   0
 .../provider_tests/fab/www/views}/__init__.py      |   0
 .../tests/provider_tests/fab/www/views/conftest.py | 124 +++++++++++++
 .../fab}/www/views/test_views_acl.py               |   2 +-
 .../fab}/www/views/test_views_custom_user_views.py |   4 +-
 pyproject.toml                                     |   3 +
 scripts/ci/docker-compose/remove-sources.yml       |   1 +
 scripts/ci/docker-compose/tests-sources.yml        |   1 +
 scripts/ci/pre_commit/version_heads_map.py         |   2 +-
 scripts/in_container/run_migration_reference.py    |   2 +-
 tests/www/views/test_views_dagrun.py               |   4 +-
 tests/www/views/test_views_home.py                 |   2 +-
 tests/www/views/test_views_tasks.py                |   4 +-
 tests/www/views/test_views_trigger_dag.py          |   4 +-
 tests/www/views/test_views_variable.py             |   2 +-
 181 files changed, 690 insertions(+), 128 deletions(-)

diff --git a/.github/boring-cyborg.yml b/.github/boring-cyborg.yml
index 13c33b81349..b844729fdd4 100644
--- a/.github/boring-cyborg.yml
+++ b/.github/boring-cyborg.yml
@@ -165,9 +165,7 @@ labelPRBasedOnFilePath:
     - providers/exasol/**
 
   provider:fab:
-    - providers/src/airflow/providers/fab/**/*
-    - docs/apache-airflow-providers-fab/**/*
-    - providers/tests/fab/**/*
+    - providers/fab/**
 
   provider:facebook:
     - providers/facebook/**
diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml
index 617ee16ab2f..d0dc9364502 100644
--- a/.pre-commit-config.yaml
+++ b/.pre-commit-config.yaml
@@ -533,9 +533,9 @@ repos:
           (?x)
           ^scripts/ci/pre_commit/version_heads_map\.py$|
           ^airflow/migrations/versions/.*$|^airflow/migrations/versions|
-          
^providers/src/airflow/providers/fab/migrations/versions/.*$|^providers/src/airflow/providers/fab/migrations/versions|
+          
^providers/fab/src/airflow/providers/fab/migrations/versions/.*$|^providers/fab/src/airflow/providers/fab/migrations/versions|
           ^airflow/utils/db.py$|
-          ^providers/src/airflow/providers/fab/auth_manager/models/db.py$
+          ^providers/fab/src/airflow/providers/fab/auth_manager/models/db.py$
         additional_dependencies: ['packaging','google-re2']
       - id: update-version
         name: Update versions in docs
@@ -624,7 +624,7 @@ repos:
           ^airflow/models/baseoperator.py$|
           ^airflow/operators/__init__.py$|
           
^providers/common/sql/tests/provider_tests/common/sql/operators/test_sql_execute.py$|
-          
^providers/src/airflow/providers/fab/www/static/css/bootstrap-theme.css$|
+          
^providers/fab/src/airflow/providers/fab/www/static/css/bootstrap-theme.css$|
           ^providers/src/airflow/providers/amazon/aws/hooks/emr.py$|
           ^providers/src/airflow/providers/amazon/aws/operators/emr.py$|
           
^providers/apache/cassandra/src/airflow/providers/apache/cassandra/hooks/cassandra.py$|
@@ -634,8 +634,8 @@ repos:
           ^providers/apache/spark/src/airflow/providers/apache/spark/hooks/|
           
^providers/apache/spark/src/airflow/providers/apache/spark/operators/|
           ^providers/exasol/src/airflow/providers/exasol/hooks/exasol.py$|
-          ^providers/src/airflow/providers/fab/auth_manager/security_manager/|
-          
^providers/src/airflow/providers/fab/www/static/css/bootstrap-theme.css$|
+          
^providers/fab/src/airflow/providers/fab/auth_manager/security_manager/|
+          
^providers/fab/src/airflow/providers/fab/www/static/css/bootstrap-theme.css$|
           ^providers/src/airflow/providers/google/cloud/hooks/bigquery.py$|
           
^providers/src/airflow/providers/google/cloud/operators/cloud_build.py$|
           ^providers/src/airflow/providers/google/cloud/operators/dataproc.py$|
@@ -662,7 +662,7 @@ repos:
           ^docs/apache-airflow-providers-apache-hdfs/connections.rst$|
           ^providers/apache/kafka/docs/connections/kafka.rst$|
           ^providers/apache/spark/docs/decorators/pyspark.rst$|
-          
^docs/apache-airflow-providers-fab/auth-manager/webserver-authentication.rst$|
+          ^providers/fab/docs/auth-manager/webserver-authentication.rst$|
           
^docs/apache-airflow-providers-google/operators/cloud/kubernetes_engine.rst$|
           
^docs/apache-airflow-providers-microsoft-azure/connections/azure_cosmos.rst$|
           ^docs/apache-airflow-providers-cncf-kubernetes/operators.rst$|
diff --git a/docs/.gitignore b/docs/.gitignore
index 274047763ca..d84366aefc0 100644
--- a/docs/.gitignore
+++ b/docs/.gitignore
@@ -28,6 +28,7 @@ apache-airflow-providers-docker
 apache-airflow-providers-edge
 apache-airflow-providers-elasticsearch
 apache-airflow-providers-exasol
+apache-airflow-providers-fab
 apache-airflow-providers-facebook
 apache-airflow-providers-ftp
 apache-airflow-providers-github
diff --git a/docs/apache-airflow-providers-fab/changelog.rst 
b/docs/apache-airflow-providers-fab/changelog.rst
deleted file mode 100644
index 41fc2e14c26..00000000000
--- a/docs/apache-airflow-providers-fab/changelog.rst
+++ /dev/null
@@ -1,25 +0,0 @@
-
- .. Licensed to the Apache Software Foundation (ASF) under one
-    or more contributor license agreements.  See the NOTICE file
-    distributed with this work for additional information
-    regarding copyright ownership.  The ASF licenses this file
-    to you under the Apache License, Version 2.0 (the
-    "License"); you may not use this file except in compliance
-    with the License.  You may obtain a copy of the License at
-
- ..   http://www.apache.org/licenses/LICENSE-2.0
-
- .. Unless required by applicable law or agreed to in writing,
-    software distributed under the License is distributed on an
-    "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
-    KIND, either express or implied.  See the License for the
-    specific language governing permissions and limitations
-    under the License.
-
- ..  NOTE! THIS FILE IS AUTOMATICALLY GENERATED AND WILL BE
-     OVERWRITTEN WHEN PREPARING PACKAGES.
-
- ..  IF YOU WANT TO MODIFY THIS FILE, YOU SHOULD MODIFY THE TEMPLATE
-     `PROVIDER_CHANGELOG_TEMPLATE.rst.jinja2` IN the 
`dev/breeze/src/airflow_breeze/templates` DIRECTORY
-
-.. include:: ../../providers/src/airflow/providers/fab/CHANGELOG.rst
diff --git a/providers/src/airflow/providers/3rd-party-licenses/LICENSES-ui.txt 
b/providers/fab/3rd-party-licenses/LICENSES-ui.txt
similarity index 98%
rename from providers/src/airflow/providers/3rd-party-licenses/LICENSES-ui.txt
rename to providers/fab/3rd-party-licenses/LICENSES-ui.txt
index db0b1fb7e13..268a4a3eeb1 100644
--- a/providers/src/airflow/providers/3rd-party-licenses/LICENSES-ui.txt
+++ b/providers/fab/3rd-party-licenses/LICENSES-ui.txt
@@ -1,5 +1,5 @@
 Apache Airflow
-Copyright 2016-2023 The Apache Software Foundation
+Copyright 2016-2025 The Apache Software Foundation
 
 This product includes software developed at The Apache Software
 Foundation (http://www.apache.org/).
diff --git a/providers/fab/README.rst b/providers/fab/README.rst
new file mode 100644
index 00000000000..3ad41250fbb
--- /dev/null
+++ b/providers/fab/README.rst
@@ -0,0 +1,86 @@
+
+ .. Licensed to the Apache Software Foundation (ASF) under one
+    or more contributor license agreements.  See the NOTICE file
+    distributed with this work for additional information
+    regarding copyright ownership.  The ASF licenses this file
+    to you under the Apache License, Version 2.0 (the
+    "License"); you may not use this file except in compliance
+    with the License.  You may obtain a copy of the License at
+
+ ..   http://www.apache.org/licenses/LICENSE-2.0
+
+ .. Unless required by applicable law or agreed to in writing,
+    software distributed under the License is distributed on an
+    "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+    KIND, either express or implied.  See the License for the
+    specific language governing permissions and limitations
+    under the License.
+
+ .. NOTE! THIS FILE IS AUTOMATICALLY GENERATED AND WILL BE OVERWRITTEN!
+
+ .. IF YOU WANT TO MODIFY TEMPLATE FOR THIS FILE, YOU SHOULD MODIFY THE 
TEMPLATE
+    `PROVIDER_README_TEMPLATE.rst.jinja2` IN the 
`dev/breeze/src/airflow_breeze/templates` DIRECTORY
+
+
+Package ``apache-airflow-providers-fab``
+
+Release: ``2.0.0``
+
+
+`Flask App Builder <https://flask-appbuilder.readthedocs.io/>`__
+
+
+Provider package
+----------------
+
+This is a provider package for ``fab`` provider. All classes for this provider 
package
+are in ``airflow.providers.fab`` python package.
+
+You can find package information and changelog for the provider
+in the `documentation 
<https://airflow.apache.org/docs/apache-airflow-providers-fab/2.0.0/>`_.
+
+Installation
+------------
+
+You can install this package on top of an existing Airflow 2 installation (see 
``Requirements`` below
+for the minimum Airflow version supported) via
+``pip install apache-airflow-providers-fab``
+
+The package supports the following python versions: 3.9,3.10,3.11,3.12
+
+Requirements
+------------
+
+==========================================  ==================
+PIP package                                 Version required
+==========================================  ==================
+``apache-airflow``                          ``>=3.0.0.dev0``
+``apache-airflow-providers-common-compat``  ``>=1.2.1``
+``flask``                                   ``>=2.2,<2.3``
+``flask-appbuilder``                        ``==4.5.3``
+``flask-login``                             ``>=0.6.2``
+``google-re2``                              ``>=1.0``
+``jmespath``                                ``>=0.7.0``
+==========================================  ==================
+
+Cross provider package dependencies
+-----------------------------------
+
+Those are dependencies that might be needed in order to use all the features 
of the package.
+You need to install the specified provider packages in order to use them.
+
+You can install such cross-provider dependencies when installing from PyPI. 
For example:
+
+.. code-block:: bash
+
+    pip install apache-airflow-providers-fab[common.compat]
+
+
+==================================================================================================================
  =================
+Dependent package                                                              
                                     Extra
+==================================================================================================================
  =================
+`apache-airflow-providers-common-compat 
<https://airflow.apache.org/docs/apache-airflow-providers-common-compat>`_  
``common.compat``
+==================================================================================================================
  =================
+
+The changelog for the provider package can be found in the
+`changelog 
<https://airflow.apache.org/docs/apache-airflow-providers-fab/2.0.0/changelog.html>`_.
diff --git a/docs/apache-airflow-providers-fab/auth-manager/access-control.rst 
b/providers/fab/docs/auth-manager/access-control.rst
similarity index 98%
rename from docs/apache-airflow-providers-fab/auth-manager/access-control.rst
rename to providers/fab/docs/auth-manager/access-control.rst
index b6271adf082..67cd0d3678b 100644
--- a/docs/apache-airflow-providers-fab/auth-manager/access-control.rst
+++ b/providers/fab/docs/auth-manager/access-control.rst
@@ -46,7 +46,7 @@ Viewer
 ^^^^^^
 ``Viewer`` users have limited read permissions:
 
-.. exampleinclude:: 
/../../providers/src/airflow/providers/fab/auth_manager/security_manager/override.py
+.. exampleinclude:: 
/../../providers/fab/src/airflow/providers/fab/auth_manager/security_manager/override.py
     :language: python
     :start-after: [START security_viewer_perms]
     :end-before: [END security_viewer_perms]
@@ -55,7 +55,7 @@ User
 ^^^^
 ``User`` users have ``Viewer`` permissions plus additional permissions:
 
-.. exampleinclude:: 
/../../providers/src/airflow/providers/fab/auth_manager/security_manager/override.py
+.. exampleinclude:: 
/../../providers/fab/src/airflow/providers/fab/auth_manager/security_manager/override.py
     :language: python
     :start-after: [START security_user_perms]
     :end-before: [END security_user_perms]
@@ -64,7 +64,7 @@ Op
 ^^
 ``Op`` users have ``User`` permissions plus additional permissions:
 
-.. exampleinclude:: 
/../../providers/src/airflow/providers/fab/auth_manager/security_manager/override.py
+.. exampleinclude:: 
/../../providers/fab/src/airflow/providers/fab/auth_manager/security_manager/override.py
     :language: python
     :start-after: [START security_op_perms]
     :end-before: [END security_op_perms]
@@ -74,7 +74,7 @@ Admin
 ``Admin`` users have all possible permissions, including granting or revoking 
permissions from
 other users. ``Admin`` users have ``Op`` permission plus additional 
permissions:
 
-.. exampleinclude:: 
/../../providers/src/airflow/providers/fab/auth_manager/security_manager/override.py
+.. exampleinclude:: 
/../../providers/fab/src/airflow/providers/fab/auth_manager/security_manager/override.py
     :language: python
     :start-after: [START security_admin_perms]
     :end-before: [END security_admin_perms]
diff --git 
a/docs/apache-airflow-providers-fab/auth-manager/api-authentication.rst 
b/providers/fab/docs/auth-manager/api-authentication.rst
similarity index 100%
rename from 
docs/apache-airflow-providers-fab/auth-manager/api-authentication.rst
rename to providers/fab/docs/auth-manager/api-authentication.rst
diff --git a/docs/apache-airflow-providers-fab/auth-manager/index.rst 
b/providers/fab/docs/auth-manager/index.rst
similarity index 100%
rename from docs/apache-airflow-providers-fab/auth-manager/index.rst
rename to providers/fab/docs/auth-manager/index.rst
diff --git 
a/docs/apache-airflow-providers-fab/auth-manager/webserver-authentication.rst 
b/providers/fab/docs/auth-manager/webserver-authentication.rst
similarity index 100%
rename from 
docs/apache-airflow-providers-fab/auth-manager/webserver-authentication.rst
rename to providers/fab/docs/auth-manager/webserver-authentication.rst
diff --git a/providers/src/airflow/providers/fab/CHANGELOG.rst 
b/providers/fab/docs/changelog.rst
similarity index 100%
rename from providers/src/airflow/providers/fab/CHANGELOG.rst
rename to providers/fab/docs/changelog.rst
diff --git a/docs/apache-airflow-providers-fab/cli-ref.rst 
b/providers/fab/docs/cli-ref.rst
similarity index 100%
rename from docs/apache-airflow-providers-fab/cli-ref.rst
rename to providers/fab/docs/cli-ref.rst
diff --git a/docs/apache-airflow-providers-fab/commits.rst 
b/providers/fab/docs/commits.rst
similarity index 100%
rename from docs/apache-airflow-providers-fab/commits.rst
rename to providers/fab/docs/commits.rst
diff --git a/docs/apache-airflow-providers-fab/configurations-ref.rst 
b/providers/fab/docs/configurations-ref.rst
similarity index 100%
rename from docs/apache-airflow-providers-fab/configurations-ref.rst
rename to providers/fab/docs/configurations-ref.rst
diff --git a/docs/apache-airflow-providers-fab/img/add-role.png 
b/providers/fab/docs/img/add-role.png
similarity index 100%
rename from docs/apache-airflow-providers-fab/img/add-role.png
rename to providers/fab/docs/img/add-role.png
diff --git 
a/docs/apache-airflow-providers-fab/img/diagram_fab_auth_manager_airflow_architecture.md5sum
 b/providers/fab/docs/img/diagram_fab_auth_manager_airflow_architecture.md5sum
similarity index 100%
rename from 
docs/apache-airflow-providers-fab/img/diagram_fab_auth_manager_airflow_architecture.md5sum
rename to 
providers/fab/docs/img/diagram_fab_auth_manager_airflow_architecture.md5sum
diff --git 
a/docs/apache-airflow-providers-fab/img/diagram_fab_auth_manager_airflow_architecture.png
 b/providers/fab/docs/img/diagram_fab_auth_manager_airflow_architecture.png
similarity index 100%
rename from 
docs/apache-airflow-providers-fab/img/diagram_fab_auth_manager_airflow_architecture.png
rename to 
providers/fab/docs/img/diagram_fab_auth_manager_airflow_architecture.png
diff --git 
a/docs/apache-airflow-providers-fab/img/diagram_fab_auth_manager_airflow_architecture.py
 b/providers/fab/docs/img/diagram_fab_auth_manager_airflow_architecture.py
similarity index 100%
rename from 
docs/apache-airflow-providers-fab/img/diagram_fab_auth_manager_airflow_architecture.py
rename to 
providers/fab/docs/img/diagram_fab_auth_manager_airflow_architecture.py
diff --git a/docs/apache-airflow-providers-fab/img/new-role.png 
b/providers/fab/docs/img/new-role.png
similarity index 100%
rename from docs/apache-airflow-providers-fab/img/new-role.png
rename to providers/fab/docs/img/new-role.png
diff --git a/docs/apache-airflow-providers-fab/index.rst 
b/providers/fab/docs/index.rst
similarity index 100%
rename from docs/apache-airflow-providers-fab/index.rst
rename to providers/fab/docs/index.rst
diff --git 
a/docs/apache-airflow-providers-fab/installing-providers-from-sources.rst 
b/providers/fab/docs/installing-providers-from-sources.rst
similarity index 100%
rename from 
docs/apache-airflow-providers-fab/installing-providers-from-sources.rst
rename to providers/fab/docs/installing-providers-from-sources.rst
diff --git a/docs/apache-airflow-providers-fab/migrations-ref.rst 
b/providers/fab/docs/migrations-ref.rst
similarity index 100%
rename from docs/apache-airflow-providers-fab/migrations-ref.rst
rename to providers/fab/docs/migrations-ref.rst
diff --git a/docs/apache-airflow-providers-fab/security.rst 
b/providers/fab/docs/security.rst
similarity index 100%
rename from docs/apache-airflow-providers-fab/security.rst
rename to providers/fab/docs/security.rst
diff --git a/docs/apache-airflow-providers-fab/stable-rest-api-ref.rst 
b/providers/fab/docs/stable-rest-api-ref.rst
similarity index 100%
rename from docs/apache-airflow-providers-fab/stable-rest-api-ref.rst
rename to providers/fab/docs/stable-rest-api-ref.rst
diff --git a/docs/apache-airflow-providers-fab/upgrading.rst 
b/providers/fab/docs/upgrading.rst
similarity index 100%
rename from docs/apache-airflow-providers-fab/upgrading.rst
rename to providers/fab/docs/upgrading.rst
diff --git a/providers/src/airflow/providers/fab/provider.yaml 
b/providers/fab/provider.yaml
similarity index 72%
rename from providers/src/airflow/providers/fab/provider.yaml
rename to providers/fab/provider.yaml
index 6f0e98240f2..82a59e64c7f 100644
--- a/providers/src/airflow/providers/fab/provider.yaml
+++ b/providers/fab/provider.yaml
@@ -50,28 +50,6 @@ versions:
   - 1.0.1
   - 1.0.0
 
-dependencies:
-  - apache-airflow>=3.0.0.dev0
-  - apache-airflow-providers-common-compat>=1.2.1
-  - flask>=2.2,<2.3
-  # We are tightly coupled with FAB version as we vendored-in part of FAB code 
related to security manager
-  # This is done as part of preparation to removing FAB as dependency, but we 
are not ready for it yet
-  # Every time we update FAB version here, please make sure that you review 
the classes and models in
-  # `airflow/providers/fab/auth_manager/security_manager/override.py` with 
their upstream counterparts.
-  # In particular, make sure any breaking changes, for example any new 
methods, are accounted for.
-  - flask-appbuilder==4.5.3
-  - flask-login>=0.6.2
-  - google-re2>=1.0
-  - jmespath>=0.7.0
-
-additional-extras:
-  - name: kerberos
-    dependencies:
-      - kerberos>=1.3.0
-
-devel-dependencies:
-  - kerberos>=1.3.0
-
 config:
   fab:
     description: This section contains configs specific to FAB provider.
diff --git a/providers/fab/pyproject.toml b/providers/fab/pyproject.toml
new file mode 100644
index 00000000000..f3c7914f6e7
--- /dev/null
+++ b/providers/fab/pyproject.toml
@@ -0,0 +1,102 @@
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+#   http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied.  See the License for the
+# specific language governing permissions and limitations
+# under the License.
+
+# NOTE! THIS FILE IS AUTOMATICALLY GENERATED AND WILL BE OVERWRITTEN!
+
+# IF YOU WANT TO MODIFY THIS FILE EXCEPT DEPENDENCIES, YOU SHOULD MODIFY THE 
TEMPLATE
+# `pyproject_TEMPLATE.toml.jinja2` IN the 
`dev/breeze/src/airflow_breeze/templates` DIRECTORY
+[build-system]
+requires = ["flit_core==3.10.1"]
+build-backend = "flit_core.buildapi"
+
+[project]
+name = "apache-airflow-providers-fab"
+version = "2.0.0"
+description = "Provider package apache-airflow-providers-fab for Apache 
Airflow"
+readme = "README.rst"
+authors = [
+    {name="Apache Software Foundation", email="[email protected]"},
+]
+maintainers = [
+    {name="Apache Software Foundation", email="[email protected]"},
+]
+keywords = [ "airflow-provider", "fab", "airflow", "integration" ]
+classifiers = [
+    "Development Status :: 5 - Production/Stable",
+    "Environment :: Console",
+    "Environment :: Web Environment",
+    "Intended Audience :: Developers",
+    "Intended Audience :: System Administrators",
+    "Framework :: Apache Airflow",
+    "Framework :: Apache Airflow :: Provider",
+    "License :: OSI Approved :: Apache Software License",
+    "Programming Language :: Python :: 3.9",
+    "Programming Language :: Python :: 3.10",
+    "Programming Language :: Python :: 3.11",
+    "Programming Language :: Python :: 3.12",
+    "Topic :: System :: Monitoring",
+]
+requires-python = "~=3.9"
+
+# The dependencies should be modified in place in the generated file
+# Any change in the dependencies is preserved when the file is regenerated
+dependencies = [
+    "apache-airflow>=3.0.0.dev0",
+    "apache-airflow-providers-common-compat>=1.2.1",
+    "flask>=2.2,<2.3",
+    # We are tightly coupled with FAB version as we vendored-in part of FAB 
code related to security manager
+    # This is done as part of preparation to removing FAB as dependency, but 
we are not ready for it yet
+    # Every time we update FAB version here, please make sure that you review 
the classes and models in
+    # `airflow/providers/fab/auth_manager/security_manager/override.py` with 
their upstream counterparts.
+    # In particular, make sure any breaking changes, for example any new 
methods, are accounted for.
+    "flask-appbuilder==4.5.3",
+    "flask-login>=0.6.2",
+    "google-re2>=1.0",
+    "jmespath>=0.7.0",
+]
+
+# The optional dependencies should be modified in place in the generated file
+# Any change in the dependencies is preserved when the file is regenerated
+[project.optional-dependencies]
+"kerberos" = [
+    "kerberos>=1.3.0",
+]
+
+# The dependency groups should be modified in place in the generated file
+# Any change in the dependencies is preserved when the file is regenerated
+[dependency-groups]
+dev = [
+    "kerberos>=1.3.0",
+]
+
+[project.urls]
+"Documentation" = 
"https://airflow.apache.org/docs/apache-airflow-providers-fab/2.0.0";
+"Changelog" = 
"https://airflow.apache.org/docs/apache-airflow-providers-fab/2.0.0/changelog.html";
+"Bug Tracker" = "https://github.com/apache/airflow/issues";
+"Source Code" = "https://github.com/apache/airflow";
+"Slack Chat" = "https://s.apache.org/airflow-slack";
+"Twitter" = "https://x.com/ApacheAirflow";
+"YouTube" = "https://www.youtube.com/channel/UCSXwxpWZQ7XZ1WL3wqevChA/";
+
+[project.entry-points."apache_airflow_provider"]
+provider_info = "airflow.providers.fab.get_provider_info:get_provider_info"
+
+[tool.flit.module]
+name = "airflow.providers.fab"
+
+[tool.pytest.ini_options]
+ignore = "tests/system/"
diff --git a/providers/fab/src/airflow/providers/fab/LICENSE 
b/providers/fab/src/airflow/providers/fab/LICENSE
new file mode 100644
index 00000000000..11069edd790
--- /dev/null
+++ b/providers/fab/src/airflow/providers/fab/LICENSE
@@ -0,0 +1,201 @@
+                              Apache License
+                        Version 2.0, January 2004
+                     http://www.apache.org/licenses/
+
+TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
+
+1. Definitions.
+
+   "License" shall mean the terms and conditions for use, reproduction,
+   and distribution as defined by Sections 1 through 9 of this document.
+
+   "Licensor" shall mean the copyright owner or entity authorized by
+   the copyright owner that is granting the License.
+
+   "Legal Entity" shall mean the union of the acting entity and all
+   other entities that control, are controlled by, or are under common
+   control with that entity. For the purposes of this definition,
+   "control" means (i) the power, direct or indirect, to cause the
+   direction or management of such entity, whether by contract or
+   otherwise, or (ii) ownership of fifty percent (50%) or more of the
+   outstanding shares, or (iii) beneficial ownership of such entity.
+
+   "You" (or "Your") shall mean an individual or Legal Entity
+   exercising permissions granted by this License.
+
+   "Source" form shall mean the preferred form for making modifications,
+   including but not limited to software source code, documentation
+   source, and configuration files.
+
+   "Object" form shall mean any form resulting from mechanical
+   transformation or translation of a Source form, including but
+   not limited to compiled object code, generated documentation,
+   and conversions to other media types.
+
+   "Work" shall mean the work of authorship, whether in Source or
+   Object form, made available under the License, as indicated by a
+   copyright notice that is included in or attached to the work
+   (an example is provided in the Appendix below).
+
+   "Derivative Works" shall mean any work, whether in Source or Object
+   form, that is based on (or derived from) the Work and for which the
+   editorial revisions, annotations, elaborations, or other modifications
+   represent, as a whole, an original work of authorship. For the purposes
+   of this License, Derivative Works shall not include works that remain
+   separable from, or merely link (or bind by name) to the interfaces of,
+   the Work and Derivative Works thereof.
+
+   "Contribution" shall mean any work of authorship, including
+   the original version of the Work and any modifications or additions
+   to that Work or Derivative Works thereof, that is intentionally
+   submitted to Licensor for inclusion in the Work by the copyright owner
+   or by an individual or Legal Entity authorized to submit on behalf of
+   the copyright owner. For the purposes of this definition, "submitted"
+   means any form of electronic, verbal, or written communication sent
+   to the Licensor or its representatives, including but not limited to
+   communication on electronic mailing lists, source code control systems,
+   and issue tracking systems that are managed by, or on behalf of, the
+   Licensor for the purpose of discussing and improving the Work, but
+   excluding communication that is conspicuously marked or otherwise
+   designated in writing by the copyright owner as "Not a Contribution."
+
+   "Contributor" shall mean Licensor and any individual or Legal Entity
+   on behalf of whom a Contribution has been received by Licensor and
+   subsequently incorporated within the Work.
+
+2. Grant of Copyright License. Subject to the terms and conditions of
+   this License, each Contributor hereby grants to You a perpetual,
+   worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+   copyright license to reproduce, prepare Derivative Works of,
+   publicly display, publicly perform, sublicense, and distribute the
+   Work and such Derivative Works in Source or Object form.
+
+3. Grant of Patent License. Subject to the terms and conditions of
+   this License, each Contributor hereby grants to You a perpetual,
+   worldwide, non-exclusive, no-charge, royalty-free, irrevocable
+   (except as stated in this section) patent license to make, have made,
+   use, offer to sell, sell, import, and otherwise transfer the Work,
+   where such license applies only to those patent claims licensable
+   by such Contributor that are necessarily infringed by their
+   Contribution(s) alone or by combination of their Contribution(s)
+   with the Work to which such Contribution(s) was submitted. If You
+   institute patent litigation against any entity (including a
+   cross-claim or counterclaim in a lawsuit) alleging that the Work
+   or a Contribution incorporated within the Work constitutes direct
+   or contributory patent infringement, then any patent licenses
+   granted to You under this License for that Work shall terminate
+   as of the date such litigation is filed.
+
+4. Redistribution. You may reproduce and distribute copies of the
+   Work or Derivative Works thereof in any medium, with or without
+   modifications, and in Source or Object form, provided that You
+   meet the following conditions:
+
+   (a) You must give any other recipients of the Work or
+       Derivative Works a copy of this License; and
+
+   (b) You must cause any modified files to carry prominent notices
+       stating that You changed the files; and
+
+   (c) You must retain, in the Source form of any Derivative Works
+       that You distribute, all copyright, patent, trademark, and
+       attribution notices from the Source form of the Work,
+       excluding those notices that do not pertain to any part of
+       the Derivative Works; and
+
+   (d) If the Work includes a "NOTICE" text file as part of its
+       distribution, then any Derivative Works that You distribute must
+       include a readable copy of the attribution notices contained
+       within such NOTICE file, excluding those notices that do not
+       pertain to any part of the Derivative Works, in at least one
+       of the following places: within a NOTICE text file distributed
+       as part of the Derivative Works; within the Source form or
+       documentation, if provided along with the Derivative Works; or,
+       within a display generated by the Derivative Works, if and
+       wherever such third-party notices normally appear. The contents
+       of the NOTICE file are for informational purposes only and
+       do not modify the License. You may add Your own attribution
+       notices within Derivative Works that You distribute, alongside
+       or as an addendum to the NOTICE text from the Work, provided
+       that such additional attribution notices cannot be construed
+       as modifying the License.
+
+   You may add Your own copyright statement to Your modifications and
+   may provide additional or different license terms and conditions
+   for use, reproduction, or distribution of Your modifications, or
+   for any such Derivative Works as a whole, provided Your use,
+   reproduction, and distribution of the Work otherwise complies with
+   the conditions stated in this License.
+
+5. Submission of Contributions. Unless You explicitly state otherwise,
+   any Contribution intentionally submitted for inclusion in the Work
+   by You to the Licensor shall be under the terms and conditions of
+   this License, without any additional terms or conditions.
+   Notwithstanding the above, nothing herein shall supersede or modify
+   the terms of any separate license agreement you may have executed
+   with Licensor regarding such Contributions.
+
+6. Trademarks. This License does not grant permission to use the trade
+   names, trademarks, service marks, or product names of the Licensor,
+   except as required for reasonable and customary use in describing the
+   origin of the Work and reproducing the content of the NOTICE file.
+
+7. Disclaimer of Warranty. Unless required by applicable law or
+   agreed to in writing, Licensor provides the Work (and each
+   Contributor provides its Contributions) on an "AS IS" BASIS,
+   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
+   implied, including, without limitation, any warranties or conditions
+   of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
+   PARTICULAR PURPOSE. You are solely responsible for determining the
+   appropriateness of using or redistributing the Work and assume any
+   risks associated with Your exercise of permissions under this License.
+
+8. Limitation of Liability. In no event and under no legal theory,
+   whether in tort (including negligence), contract, or otherwise,
+   unless required by applicable law (such as deliberate and grossly
+   negligent acts) or agreed to in writing, shall any Contributor be
+   liable to You for damages, including any direct, indirect, special,
+   incidental, or consequential damages of any character arising as a
+   result of this License or out of the use or inability to use the
+   Work (including but not limited to damages for loss of goodwill,
+   work stoppage, computer failure or malfunction, or any and all
+   other commercial damages or losses), even if such Contributor
+   has been advised of the possibility of such damages.
+
+9. Accepting Warranty or Additional Liability. While redistributing
+   the Work or Derivative Works thereof, You may choose to offer,
+   and charge a fee for, acceptance of support, warranty, indemnity,
+   or other liability obligations and/or rights consistent with this
+   License. However, in accepting such obligations, You may act only
+   on Your own behalf and on Your sole responsibility, not on behalf
+   of any other Contributor, and only if You agree to indemnify,
+   defend, and hold each Contributor harmless for any liability
+   incurred by, or claims asserted against, such Contributor by reason
+   of your accepting any such warranty or additional liability.
+
+END OF TERMS AND CONDITIONS
+
+APPENDIX: How to apply the Apache License to your work.
+
+   To apply the Apache License to your work, attach the following
+   boilerplate notice, with the fields enclosed by brackets "[]"
+   replaced with your own identifying information. (Don't include
+   the brackets!)  The text should be enclosed in the appropriate
+   comment syntax for the file format. We also recommend that a
+   file or class name and description of purpose be included on the
+   same "printed page" as the copyright notice for easier
+   identification within third-party archives.
+
+Copyright [yyyy] [name of copyright owner]
+
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+    http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
diff --git a/providers/src/airflow/providers/fab/__init__.py 
b/providers/fab/src/airflow/providers/fab/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/__init__.py
rename to providers/fab/src/airflow/providers/fab/__init__.py
diff --git a/providers/src/airflow/providers/fab/alembic.ini 
b/providers/fab/src/airflow/providers/fab/alembic.ini
similarity index 100%
rename from providers/src/airflow/providers/fab/alembic.ini
rename to providers/fab/src/airflow/providers/fab/alembic.ini
diff --git a/providers/src/airflow/providers/fab/auth_manager/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/__init__.py
similarity index 100%
copy from providers/src/airflow/providers/fab/auth_manager/__init__.py
copy to providers/fab/src/airflow/providers/fab/auth_manager/__init__.py
diff --git a/providers/src/airflow/providers/fab/auth_manager/api/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/api/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/api/__init__.py
rename to providers/fab/src/airflow/providers/fab/auth_manager/api/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/api/auth/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/api/auth/__init__.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/api/auth/__init__.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/api/auth/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/api/auth/backend/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/api/auth/backend/__init__.py
similarity index 100%
copy from 
providers/src/airflow/providers/fab/auth_manager/api/auth/backend/__init__.py
copy to 
providers/fab/src/airflow/providers/fab/auth_manager/api/auth/backend/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/api/auth/backend/basic_auth.py
 
b/providers/fab/src/airflow/providers/fab/auth_manager/api/auth/backend/basic_auth.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/api/auth/backend/basic_auth.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/api/auth/backend/basic_auth.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/api/auth/backend/kerberos_auth.py
 
b/providers/fab/src/airflow/providers/fab/auth_manager/api/auth/backend/kerberos_auth.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/api/auth/backend/kerberos_auth.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/api/auth/backend/kerberos_auth.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/api/auth/backend/session.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/api/auth/backend/session.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/api/auth/backend/session.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/api/auth/backend/session.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/api_endpoints/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/api_endpoints/__init__.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/api_endpoints/__init__.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/api_endpoints/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/api_endpoints/role_and_permission_endpoint.py
 
b/providers/fab/src/airflow/providers/fab/auth_manager/api_endpoints/role_and_permission_endpoint.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/api_endpoints/role_and_permission_endpoint.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/api_endpoints/role_and_permission_endpoint.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/api_endpoints/user_endpoint.py
 
b/providers/fab/src/airflow/providers/fab/auth_manager/api_endpoints/user_endpoint.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/api_endpoints/user_endpoint.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/api_endpoints/user_endpoint.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/cli_commands/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/__init__.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/cli_commands/__init__.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/cli_commands/db_command.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/db_command.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/cli_commands/db_command.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/db_command.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/cli_commands/definition.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/definition.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/cli_commands/definition.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/definition.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/cli_commands/role_command.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/role_command.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/cli_commands/role_command.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/role_command.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/cli_commands/sync_perm_command.py
 
b/providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/sync_perm_command.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/cli_commands/sync_perm_command.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/sync_perm_command.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/cli_commands/user_command.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/user_command.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/cli_commands/user_command.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/user_command.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/cli_commands/utils.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/utils.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/cli_commands/utils.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/cli_commands/utils.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/fab_auth_manager.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/fab_auth_manager.py
similarity index 98%
rename from providers/src/airflow/providers/fab/auth_manager/fab_auth_manager.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/fab_auth_manager.py
index 4060f753444..c3d086b56e1 100644
--- a/providers/src/airflow/providers/fab/auth_manager/fab_auth_manager.py
+++ b/providers/fab/src/airflow/providers/fab/auth_manager/fab_auth_manager.py
@@ -313,9 +313,11 @@ class FabAuthManager(BaseAuthManager[User]):
                 return False
 
             return all(
-                self._is_authorized(method=method, 
resource_type=resource_type, user=user)
-                if resource_type != RESOURCE_DAG_RUN or not 
hasattr(permissions, "resource_name")
-                else self._is_authorized_dag_run(method=method, 
details=details, user=user)
+                (
+                    self._is_authorized(method=method, 
resource_type=resource_type, user=user)
+                    if resource_type != RESOURCE_DAG_RUN or not 
hasattr(permissions, "resource_name")
+                    else self._is_authorized_dag_run(method=method, 
details=details, user=user)
+                )
                 for resource_type in resource_types
             )
 
@@ -456,8 +458,8 @@ class FabAuthManager(BaseAuthManager[User]):
 
     def get_url_user_profile(self) -> str | None:
         """Return the url to a page displaying info about the current user."""
-        if not self.security_manager.user_view or 
self.appbuilder.get_app.config.get(
-            "AUTH_ROLE_PUBLIC", None
+        if not self.security_manager.user_view or (
+            self.appbuilder and 
self.appbuilder.get_app.config.get("AUTH_ROLE_PUBLIC", None)
         ):
             return None
         return url_for(f"{self.security_manager.user_view.endpoint}.userinfo")
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/models/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/models/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/models/__init__.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/models/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/models/anonymous_user.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/models/anonymous_user.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/models/anonymous_user.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/models/anonymous_user.py
diff --git a/providers/src/airflow/providers/fab/auth_manager/models/db.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/models/db.py
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/models/db.py
rename to providers/fab/src/airflow/providers/fab/auth_manager/models/db.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/openapi/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/openapi/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/openapi/__init__.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/openapi/__init__.py
diff --git a/providers/src/airflow/providers/fab/auth_manager/openapi/v1.yaml 
b/providers/fab/src/airflow/providers/fab/auth_manager/openapi/v1.yaml
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/openapi/v1.yaml
rename to providers/fab/src/airflow/providers/fab/auth_manager/openapi/v1.yaml
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/schemas/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/schemas/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/schemas/__init__.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/schemas/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/schemas/role_and_permission_schema.py
 
b/providers/fab/src/airflow/providers/fab/auth_manager/schemas/role_and_permission_schema.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/schemas/role_and_permission_schema.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/schemas/role_and_permission_schema.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/schemas/user_schema.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/schemas/user_schema.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/schemas/user_schema.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/schemas/user_schema.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/security_manager/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/security_manager/__init__.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/security_manager/__init__.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/security_manager/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/security_manager/constants.py
 
b/providers/fab/src/airflow/providers/fab/auth_manager/security_manager/constants.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/security_manager/constants.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/security_manager/constants.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/security_manager/override.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/security_manager/override.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/security_manager/override.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/security_manager/override.py
diff --git a/providers/src/airflow/providers/fab/auth_manager/views/__init__.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/views/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/views/__init__.py
rename to providers/fab/src/airflow/providers/fab/auth_manager/views/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/views/permissions.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/views/permissions.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/auth_manager/views/permissions.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/views/permissions.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/views/roles_list.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/views/roles_list.py
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/views/roles_list.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/views/roles_list.py
diff --git a/providers/src/airflow/providers/fab/auth_manager/views/user.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/views/user.py
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/views/user.py
rename to providers/fab/src/airflow/providers/fab/auth_manager/views/user.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/views/user_edit.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/views/user_edit.py
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/views/user_edit.py
rename to 
providers/fab/src/airflow/providers/fab/auth_manager/views/user_edit.py
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/views/user_stats.py 
b/providers/fab/src/airflow/providers/fab/auth_manager/views/user_stats.py
similarity index 100%
copy from providers/src/airflow/providers/fab/auth_manager/views/user_stats.py
copy to providers/fab/src/airflow/providers/fab/auth_manager/views/user_stats.py
diff --git a/providers/fab/src/airflow/providers/fab/get_provider_info.py 
b/providers/fab/src/airflow/providers/fab/get_provider_info.py
new file mode 100644
index 00000000000..4624796d5c3
--- /dev/null
+++ b/providers/fab/src/airflow/providers/fab/get_provider_info.py
@@ -0,0 +1,90 @@
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+#   http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied.  See the License for the
+# specific language governing permissions and limitations
+# under the License.
+
+# NOTE! THIS FILE IS AUTOMATICALLY GENERATED AND WILL BE OVERWRITTEN!
+#
+# IF YOU WANT TO MODIFY THIS FILE, YOU SHOULD MODIFY THE TEMPLATE
+# `get_provider_info_TEMPLATE.py.jinja2` IN the 
`dev/breeze/src/airflow_breeze/templates` DIRECTORY
+
+
+def get_provider_info():
+    return {
+        "package-name": "apache-airflow-providers-fab",
+        "name": "Fab",
+        "description": "`Flask App Builder 
<https://flask-appbuilder.readthedocs.io/>`__\n",
+        "state": "ready",
+        "source-date-epoch": 1731570160,
+        "versions": [
+            "2.0.0",
+            "1.5.2",
+            "1.5.1",
+            "1.5.0",
+            "1.4.1",
+            "1.4.0",
+            "1.3.0",
+            "1.2.2",
+            "1.2.1",
+            "1.2.0",
+            "1.1.1",
+            "1.1.0",
+            "1.0.4",
+            "1.0.3",
+            "1.0.2",
+            "1.0.1",
+            "1.0.0",
+        ],
+        "config": {
+            "fab": {
+                "description": "This section contains configs specific to FAB 
provider.",
+                "options": {
+                    "auth_rate_limited": {
+                        "description": "Boolean for enabling rate limiting on 
authentication endpoints.\n",
+                        "version_added": "1.0.2",
+                        "type": "boolean",
+                        "example": None,
+                        "default": "True",
+                    },
+                    "auth_rate_limit": {
+                        "description": "Rate limit for authentication 
endpoints.\n",
+                        "version_added": "1.0.2",
+                        "type": "string",
+                        "example": None,
+                        "default": "5 per 40 second",
+                    },
+                    "update_fab_perms": {
+                        "description": "Update FAB permissions and sync 
security manager roles\non webserver startup\n",
+                        "version_added": "1.0.2",
+                        "type": "string",
+                        "example": None,
+                        "default": "True",
+                    },
+                },
+            }
+        },
+        "auth-managers": 
["airflow.providers.fab.auth_manager.fab_auth_manager.FabAuthManager"],
+        "dependencies": [
+            "apache-airflow>=3.0.0.dev0",
+            "apache-airflow-providers-common-compat>=1.2.1",
+            "flask>=2.2,<2.3",
+            "flask-appbuilder==4.5.3",
+            "flask-login>=0.6.2",
+            "google-re2>=1.0",
+            "jmespath>=0.7.0",
+        ],
+        "optional-dependencies": {"kerberos": ["kerberos>=1.3.0"]},
+        "devel-dependencies": ["kerberos>=1.3.0"],
+    }
diff --git a/providers/src/airflow/providers/fab/migrations/README 
b/providers/fab/src/airflow/providers/fab/migrations/README
similarity index 100%
rename from providers/src/airflow/providers/fab/migrations/README
rename to providers/fab/src/airflow/providers/fab/migrations/README
diff --git a/providers/src/airflow/providers/fab/migrations/__init__.py 
b/providers/fab/src/airflow/providers/fab/migrations/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/migrations/__init__.py
rename to providers/fab/src/airflow/providers/fab/migrations/__init__.py
diff --git a/providers/src/airflow/providers/fab/migrations/env.py 
b/providers/fab/src/airflow/providers/fab/migrations/env.py
similarity index 100%
rename from providers/src/airflow/providers/fab/migrations/env.py
rename to providers/fab/src/airflow/providers/fab/migrations/env.py
diff --git a/providers/src/airflow/providers/fab/migrations/script.py.mako 
b/providers/fab/src/airflow/providers/fab/migrations/script.py.mako
similarity index 100%
rename from providers/src/airflow/providers/fab/migrations/script.py.mako
rename to providers/fab/src/airflow/providers/fab/migrations/script.py.mako
diff --git 
a/providers/src/airflow/providers/fab/migrations/versions/0001_1_4_0_placeholder_migration.py
 
b/providers/fab/src/airflow/providers/fab/migrations/versions/0001_1_4_0_placeholder_migration.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/migrations/versions/0001_1_4_0_placeholder_migration.py
rename to 
providers/fab/src/airflow/providers/fab/migrations/versions/0001_1_4_0_placeholder_migration.py
diff --git 
a/providers/src/airflow/providers/fab/migrations/versions/__init__.py 
b/providers/fab/src/airflow/providers/fab/migrations/versions/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/migrations/versions/__init__.py
rename to 
providers/fab/src/airflow/providers/fab/migrations/versions/__init__.py
diff --git a/providers/src/airflow/providers/fab/www/__init__.py 
b/providers/fab/src/airflow/providers/fab/www/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/__init__.py
rename to providers/fab/src/airflow/providers/fab/www/__init__.py
diff --git a/providers/src/airflow/providers/fab/www/api_connexion/__init__.py 
b/providers/fab/src/airflow/providers/fab/www/api_connexion/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/api_connexion/__init__.py
rename to providers/fab/src/airflow/providers/fab/www/api_connexion/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/www/api_connexion/exceptions.py 
b/providers/fab/src/airflow/providers/fab/www/api_connexion/exceptions.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/api_connexion/exceptions.py
rename to 
providers/fab/src/airflow/providers/fab/www/api_connexion/exceptions.py
diff --git 
a/providers/src/airflow/providers/fab/www/api_connexion/parameters.py 
b/providers/fab/src/airflow/providers/fab/www/api_connexion/parameters.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/api_connexion/parameters.py
rename to 
providers/fab/src/airflow/providers/fab/www/api_connexion/parameters.py
diff --git a/providers/src/airflow/providers/fab/www/api_connexion/security.py 
b/providers/fab/src/airflow/providers/fab/www/api_connexion/security.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/api_connexion/security.py
rename to providers/fab/src/airflow/providers/fab/www/api_connexion/security.py
diff --git a/providers/src/airflow/providers/fab/www/api_connexion/types.py 
b/providers/fab/src/airflow/providers/fab/www/api_connexion/types.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/api_connexion/types.py
rename to providers/fab/src/airflow/providers/fab/www/api_connexion/types.py
diff --git a/providers/src/airflow/providers/fab/www/app.py 
b/providers/fab/src/airflow/providers/fab/www/app.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/app.py
rename to providers/fab/src/airflow/providers/fab/www/app.py
diff --git a/providers/src/airflow/providers/fab/www/constants.py 
b/providers/fab/src/airflow/providers/fab/www/constants.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/constants.py
rename to providers/fab/src/airflow/providers/fab/www/constants.py
diff --git a/providers/src/airflow/providers/fab/www/extensions/__init__.py 
b/providers/fab/src/airflow/providers/fab/www/extensions/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/extensions/__init__.py
rename to providers/fab/src/airflow/providers/fab/www/extensions/__init__.py
diff --git 
a/providers/src/airflow/providers/fab/www/extensions/init_appbuilder.py 
b/providers/fab/src/airflow/providers/fab/www/extensions/init_appbuilder.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/extensions/init_appbuilder.py
rename to 
providers/fab/src/airflow/providers/fab/www/extensions/init_appbuilder.py
diff --git 
a/providers/src/airflow/providers/fab/www/extensions/init_jinja_globals.py 
b/providers/fab/src/airflow/providers/fab/www/extensions/init_jinja_globals.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/extensions/init_jinja_globals.py
rename to 
providers/fab/src/airflow/providers/fab/www/extensions/init_jinja_globals.py
diff --git 
a/providers/src/airflow/providers/fab/www/extensions/init_manifest_files.py 
b/providers/fab/src/airflow/providers/fab/www/extensions/init_manifest_files.py
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/extensions/init_manifest_files.py
rename to 
providers/fab/src/airflow/providers/fab/www/extensions/init_manifest_files.py
diff --git 
a/providers/src/airflow/providers/fab/www/extensions/init_security.py 
b/providers/fab/src/airflow/providers/fab/www/extensions/init_security.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/extensions/init_security.py
rename to 
providers/fab/src/airflow/providers/fab/www/extensions/init_security.py
diff --git a/providers/src/airflow/providers/fab/www/extensions/init_session.py 
b/providers/fab/src/airflow/providers/fab/www/extensions/init_session.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/extensions/init_session.py
rename to providers/fab/src/airflow/providers/fab/www/extensions/init_session.py
diff --git a/providers/src/airflow/providers/fab/www/extensions/init_views.py 
b/providers/fab/src/airflow/providers/fab/www/extensions/init_views.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/extensions/init_views.py
rename to providers/fab/src/airflow/providers/fab/www/extensions/init_views.py
diff --git a/providers/src/airflow/providers/fab/www/package-lock.json 
b/providers/fab/src/airflow/providers/fab/www/package-lock.json
similarity index 100%
rename from providers/src/airflow/providers/fab/www/package-lock.json
rename to providers/fab/src/airflow/providers/fab/www/package-lock.json
diff --git a/providers/src/airflow/providers/fab/www/package.json 
b/providers/fab/src/airflow/providers/fab/www/package.json
similarity index 100%
rename from providers/src/airflow/providers/fab/www/package.json
rename to providers/fab/src/airflow/providers/fab/www/package.json
diff --git a/providers/src/airflow/providers/fab/www/security/__init__.py 
b/providers/fab/src/airflow/providers/fab/www/security/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/security/__init__.py
rename to providers/fab/src/airflow/providers/fab/www/security/__init__.py
diff --git a/providers/src/airflow/providers/fab/www/security/permissions.py 
b/providers/fab/src/airflow/providers/fab/www/security/permissions.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/security/permissions.py
rename to providers/fab/src/airflow/providers/fab/www/security/permissions.py
diff --git a/providers/src/airflow/providers/fab/www/security_manager.py 
b/providers/fab/src/airflow/providers/fab/www/security_manager.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/security_manager.py
rename to providers/fab/src/airflow/providers/fab/www/security_manager.py
diff --git a/providers/src/airflow/providers/fab/www/session.py 
b/providers/fab/src/airflow/providers/fab/www/session.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/session.py
rename to providers/fab/src/airflow/providers/fab/www/session.py
diff --git 
a/providers/src/airflow/providers/fab/www/static/css/bootstrap-theme.css 
b/providers/fab/src/airflow/providers/fab/www/static/css/bootstrap-theme.css
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/static/css/bootstrap-theme.css
rename to 
providers/fab/src/airflow/providers/fab/www/static/css/bootstrap-theme.css
diff --git 
a/providers/src/airflow/providers/fab/www/static/css/loading-dots.css 
b/providers/fab/src/airflow/providers/fab/www/static/css/loading-dots.css
similarity index 100%
rename from providers/src/airflow/providers/fab/www/static/css/loading-dots.css
rename to 
providers/fab/src/airflow/providers/fab/www/static/css/loading-dots.css
diff --git a/providers/src/airflow/providers/fab/www/static/css/main.css 
b/providers/fab/src/airflow/providers/fab/www/static/css/main.css
similarity index 100%
rename from providers/src/airflow/providers/fab/www/static/css/main.css
rename to providers/fab/src/airflow/providers/fab/www/static/css/main.css
diff --git 
a/providers/src/airflow/providers/fab/www/static/css/material-icons.css 
b/providers/fab/src/airflow/providers/fab/www/static/css/material-icons.css
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/static/css/material-icons.css
rename to 
providers/fab/src/airflow/providers/fab/www/static/css/material-icons.css
diff --git 
a/providers/src/airflow/providers/fab/www/static/js/datetime_utils.js 
b/providers/fab/src/airflow/providers/fab/www/static/js/datetime_utils.js
similarity index 100%
rename from providers/src/airflow/providers/fab/www/static/js/datetime_utils.js
rename to 
providers/fab/src/airflow/providers/fab/www/static/js/datetime_utils.js
diff --git a/providers/src/airflow/providers/fab/www/static/js/main.js 
b/providers/fab/src/airflow/providers/fab/www/static/js/main.js
similarity index 100%
rename from providers/src/airflow/providers/fab/www/static/js/main.js
rename to providers/fab/src/airflow/providers/fab/www/static/js/main.js
diff --git a/providers/src/airflow/providers/fab/www/static/sort_asc.png 
b/providers/fab/src/airflow/providers/fab/www/static/sort_asc.png
similarity index 100%
rename from providers/src/airflow/providers/fab/www/static/sort_asc.png
rename to providers/fab/src/airflow/providers/fab/www/static/sort_asc.png
diff --git a/providers/src/airflow/providers/fab/www/static/sort_both.png 
b/providers/fab/src/airflow/providers/fab/www/static/sort_both.png
similarity index 100%
rename from providers/src/airflow/providers/fab/www/static/sort_both.png
rename to providers/fab/src/airflow/providers/fab/www/static/sort_both.png
diff --git a/providers/src/airflow/providers/fab/www/static/sort_desc.png 
b/providers/fab/src/airflow/providers/fab/www/static/sort_desc.png
similarity index 100%
rename from providers/src/airflow/providers/fab/www/static/sort_desc.png
rename to providers/fab/src/airflow/providers/fab/www/static/sort_desc.png
diff --git 
a/providers/src/airflow/providers/fab/www/templates/airflow/_messages.html 
b/providers/fab/src/airflow/providers/fab/www/templates/airflow/_messages.html
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/templates/airflow/_messages.html
rename to 
providers/fab/src/airflow/providers/fab/www/templates/airflow/_messages.html
diff --git 
a/providers/src/airflow/providers/fab/www/templates/airflow/error.html 
b/providers/fab/src/airflow/providers/fab/www/templates/airflow/error.html
similarity index 100%
rename from providers/src/airflow/providers/fab/www/templates/airflow/error.html
rename to 
providers/fab/src/airflow/providers/fab/www/templates/airflow/error.html
diff --git 
a/providers/src/airflow/providers/fab/www/templates/airflow/main.html 
b/providers/fab/src/airflow/providers/fab/www/templates/airflow/main.html
similarity index 100%
rename from providers/src/airflow/providers/fab/www/templates/airflow/main.html
rename to 
providers/fab/src/airflow/providers/fab/www/templates/airflow/main.html
diff --git 
a/providers/src/airflow/providers/fab/www/templates/airflow/traceback.html 
b/providers/fab/src/airflow/providers/fab/www/templates/airflow/traceback.html
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/templates/airflow/traceback.html
rename to 
providers/fab/src/airflow/providers/fab/www/templates/airflow/traceback.html
diff --git 
a/providers/src/airflow/providers/fab/www/templates/appbuilder/index.html 
b/providers/fab/src/airflow/providers/fab/www/templates/appbuilder/index.html
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/templates/appbuilder/index.html
rename to 
providers/fab/src/airflow/providers/fab/www/templates/appbuilder/index.html
diff --git 
a/providers/src/airflow/providers/fab/www/templates/appbuilder/navbar.html 
b/providers/fab/src/airflow/providers/fab/www/templates/appbuilder/navbar.html
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/templates/appbuilder/navbar.html
rename to 
providers/fab/src/airflow/providers/fab/www/templates/appbuilder/navbar.html
diff --git 
a/providers/src/airflow/providers/fab/www/templates/appbuilder/navbar_menu.html 
b/providers/fab/src/airflow/providers/fab/www/templates/appbuilder/navbar_menu.html
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/templates/appbuilder/navbar_menu.html
rename to 
providers/fab/src/airflow/providers/fab/www/templates/appbuilder/navbar_menu.html
diff --git 
a/providers/src/airflow/providers/fab/www/templates/appbuilder/navbar_right.html
 
b/providers/fab/src/airflow/providers/fab/www/templates/appbuilder/navbar_right.html
similarity index 100%
rename from 
providers/src/airflow/providers/fab/www/templates/appbuilder/navbar_right.html
rename to 
providers/fab/src/airflow/providers/fab/www/templates/appbuilder/navbar_right.html
diff --git a/providers/src/airflow/providers/fab/www/utils.py 
b/providers/fab/src/airflow/providers/fab/www/utils.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/utils.py
rename to providers/fab/src/airflow/providers/fab/www/utils.py
diff --git a/providers/src/airflow/providers/fab/www/views.py 
b/providers/fab/src/airflow/providers/fab/www/views.py
similarity index 100%
rename from providers/src/airflow/providers/fab/www/views.py
rename to providers/fab/src/airflow/providers/fab/www/views.py
diff --git a/providers/src/airflow/providers/fab/www/webpack.config.js 
b/providers/fab/src/airflow/providers/fab/www/webpack.config.js
similarity index 100%
rename from providers/src/airflow/providers/fab/www/webpack.config.js
rename to providers/fab/src/airflow/providers/fab/www/webpack.config.js
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/views/user_stats.py 
b/providers/fab/tests/conftest.py
similarity index 61%
rename from providers/src/airflow/providers/fab/auth_manager/views/user_stats.py
rename to providers/fab/tests/conftest.py
index 0431e74cd59..068fe6bbf5a 100644
--- a/providers/src/airflow/providers/fab/auth_manager/views/user_stats.py
+++ b/providers/fab/tests/conftest.py
@@ -16,18 +16,17 @@
 # under the License.
 from __future__ import annotations
 
-from flask_appbuilder.security.views import UserStatsChartView
+import pathlib
 
-from airflow.providers.fab.www.security import permissions
+import pytest
 
+pytest_plugins = "tests_common.pytest_plugin"
 
-class CustomUserStatsChartView(UserStatsChartView):
-    """Customize permission names for FAB's builtin UserStatsChartView."""
 
-    class_permission_name = permissions.RESOURCE_USER_STATS_CHART
-    route_base = "/userstatschartview"
-    method_permission_name = {
-        "chart": "read",
-        "list": "read",
-    }
-    base_permissions = [permissions.ACTION_CAN_READ]
[email protected](tryfirst=True)
+def pytest_configure(config: pytest.Config) -> None:
+    deprecations_ignore_path = 
pathlib.Path(__file__).parent.joinpath("deprecations_ignore.yml")
+    dep_path = [deprecations_ignore_path] if deprecations_ignore_path.exists() 
else []
+    config.inicfg["airflow_deprecations_ignore"] = (
+        config.inicfg.get("airflow_deprecations_ignore", []) + dep_path  # 
type: ignore[assignment,operator]
+    )
diff --git 
a/providers/src/airflow/providers/fab/auth_manager/api/auth/backend/__init__.py 
b/providers/fab/tests/provider_tests/__init__.py
similarity index 90%
rename from 
providers/src/airflow/providers/fab/auth_manager/api/auth/backend/__init__.py
rename to providers/fab/tests/provider_tests/__init__.py
index 217e5db9607..e8fd2285643 100644
--- 
a/providers/src/airflow/providers/fab/auth_manager/api/auth/backend/__init__.py
+++ b/providers/fab/tests/provider_tests/__init__.py
@@ -1,4 +1,3 @@
-#
 # Licensed to the Apache Software Foundation (ASF) under one
 # or more contributor license agreements.  See the NOTICE file
 # distributed with this work for additional information
@@ -15,3 +14,4 @@
 # KIND, either express or implied.  See the License for the
 # specific language governing permissions and limitations
 # under the License.
+__path__ = __import__("pkgutil").extend_path(__path__, __name__)  # type: 
ignore
diff --git a/providers/tests/fab/__init__.py 
b/providers/fab/tests/provider_tests/fab/__init__.py
similarity index 100%
rename from providers/tests/fab/__init__.py
rename to providers/fab/tests/provider_tests/fab/__init__.py
diff --git a/providers/tests/fab/auth_manager/__init__.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/__init__.py
similarity index 100%
rename from providers/tests/fab/auth_manager/__init__.py
rename to providers/fab/tests/provider_tests/fab/auth_manager/__init__.py
diff --git a/providers/tests/fab/auth_manager/api/__init__.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api/__init__.py
similarity index 100%
rename from providers/tests/fab/auth_manager/api/__init__.py
rename to providers/fab/tests/provider_tests/fab/auth_manager/api/__init__.py
diff --git a/providers/tests/fab/auth_manager/api/auth/__init__.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api/auth/__init__.py
similarity index 100%
rename from providers/tests/fab/auth_manager/api/auth/__init__.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api/auth/__init__.py
diff --git a/providers/tests/fab/auth_manager/api/auth/backend/__init__.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api/auth/backend/__init__.py
similarity index 100%
rename from providers/tests/fab/auth_manager/api/auth/backend/__init__.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api/auth/backend/__init__.py
diff --git 
a/providers/tests/fab/auth_manager/api/auth/backend/test_basic_auth.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api/auth/backend/test_basic_auth.py
similarity index 100%
rename from providers/tests/fab/auth_manager/api/auth/backend/test_basic_auth.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api/auth/backend/test_basic_auth.py
diff --git 
a/providers/tests/fab/auth_manager/api/auth/backend/test_kerberos_auth.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api/auth/backend/test_kerberos_auth.py
similarity index 100%
rename from 
providers/tests/fab/auth_manager/api/auth/backend/test_kerberos_auth.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api/auth/backend/test_kerberos_auth.py
diff --git a/providers/tests/fab/auth_manager/api/auth/backend/test_session.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api/auth/backend/test_session.py
similarity index 100%
rename from providers/tests/fab/auth_manager/api/auth/backend/test_session.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api/auth/backend/test_session.py
diff --git a/providers/tests/fab/auth_manager/api_endpoints/__init__.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/__init__.py
similarity index 100%
rename from providers/tests/fab/auth_manager/api_endpoints/__init__.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/__init__.py
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/api_connexion_utils.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/api_connexion_utils.py
similarity index 100%
rename from 
providers/tests/fab/auth_manager/api_endpoints/api_connexion_utils.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/api_connexion_utils.py
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/remote_user_api_auth_backend.py
 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/remote_user_api_auth_backend.py
similarity index 100%
rename from 
providers/tests/fab/auth_manager/api_endpoints/remote_user_api_auth_backend.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/remote_user_api_auth_backend.py
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_asset_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_asset_endpoint.py
similarity index 99%
rename from 
providers/tests/fab/auth_manager/api_endpoints/test_asset_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_asset_endpoint.py
index 29eb85acb06..97813f14f4e 100644
--- a/providers/tests/fab/auth_manager/api_endpoints/test_asset_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_asset_endpoint.py
@@ -24,8 +24,8 @@ import time_machine
 from airflow.providers.fab.www.api_connexion.exceptions import 
EXCEPTIONS_LINK_MAP
 from airflow.providers.fab.www.security import permissions
 from airflow.utils import timezone
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 from tests_common.test_utils.db import clear_db_assets, clear_db_runs
 from tests_common.test_utils.version_compat import AIRFLOW_V_3_0_PLUS
 from tests_common.test_utils.www import _check_last_log
diff --git a/providers/tests/fab/auth_manager/api_endpoints/test_auth.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_auth.py
similarity index 100%
rename from providers/tests/fab/auth_manager/api_endpoints/test_auth.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_auth.py
diff --git a/providers/tests/fab/auth_manager/api_endpoints/test_cors.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_cors.py
similarity index 100%
rename from providers/tests/fab/auth_manager/api_endpoints/test_cors.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_cors.py
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_dag_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_endpoint.py
similarity index 98%
rename from providers/tests/fab/auth_manager/api_endpoints/test_dag_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_endpoint.py
index 9b7ba51f25b..e842650a4f2 100644
--- a/providers/tests/fab/auth_manager/api_endpoints/test_dag_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_endpoint.py
@@ -23,8 +23,8 @@ from airflow.models import DagModel
 from airflow.providers.fab.www.api_connexion.exceptions import 
EXCEPTIONS_LINK_MAP
 from airflow.providers.fab.www.security import permissions
 from airflow.utils.session import provide_session
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 from tests_common.test_utils.db import clear_db_dags, clear_db_runs, 
clear_db_serialized_dags
 from tests_common.test_utils.version_compat import AIRFLOW_V_3_0_PLUS
 from tests_common.test_utils.www import _check_last_log
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_dag_run_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_run_endpoint.py
similarity index 99%
rename from 
providers/tests/fab/auth_manager/api_endpoints/test_dag_run_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_run_endpoint.py
index d0aecf20f92..1a297b008cf 100644
--- a/providers/tests/fab/auth_manager/api_endpoints/test_dag_run_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_run_endpoint.py
@@ -27,12 +27,12 @@ from airflow.sdk.definitions.param import Param
 from airflow.utils import timezone
 from airflow.utils.session import create_session
 from airflow.utils.state import DagRunState
-
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
(
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import (
     create_user,
     delete_roles,
     delete_user,
 )
+
 from tests_common.test_utils.db import clear_db_dags, clear_db_runs, 
clear_db_serialized_dags
 from tests_common.test_utils.version_compat import AIRFLOW_V_3_0_PLUS
 
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_dag_source_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_source_endpoint.py
similarity index 97%
rename from 
providers/tests/fab/auth_manager/api_endpoints/test_dag_source_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_source_endpoint.py
index 66cd6477c9e..7cb7b7e7201 100644
--- a/providers/tests/fab/auth_manager/api_endpoints/test_dag_source_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_source_endpoint.py
@@ -23,8 +23,8 @@ import pytest
 
 from airflow.models import DagBag
 from airflow.providers.fab.www.security import permissions
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 from tests_common.test_utils.db import (
     clear_db_dag_code,
     clear_db_dags,
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_dag_warning_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_warning_endpoint.py
similarity index 96%
rename from 
providers/tests/fab/auth_manager/api_endpoints/test_dag_warning_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_warning_endpoint.py
index 34862c6b4c7..1b1f9455d68 100644
--- 
a/providers/tests/fab/auth_manager/api_endpoints/test_dag_warning_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_dag_warning_endpoint.py
@@ -22,8 +22,8 @@ from airflow.models.dag import DagModel
 from airflow.models.dagwarning import DagWarning
 from airflow.providers.fab.www.security import permissions
 from airflow.utils.session import create_session
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 from tests_common.test_utils.db import clear_db_dag_warnings, clear_db_dags
 from tests_common.test_utils.version_compat import AIRFLOW_V_3_0_PLUS
 
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_event_log_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_event_log_endpoint.py
similarity index 98%
rename from 
providers/tests/fab/auth_manager/api_endpoints/test_event_log_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_event_log_endpoint.py
index 168bcae4b9f..d49dc5d25df 100644
--- a/providers/tests/fab/auth_manager/api_endpoints/test_event_log_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_event_log_endpoint.py
@@ -21,8 +21,8 @@ import pytest
 from airflow.models import Log
 from airflow.providers.fab.www.security import permissions
 from airflow.utils import timezone
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 from tests_common.test_utils.db import clear_db_logs
 from tests_common.test_utils.version_compat import AIRFLOW_V_3_0_PLUS
 
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_import_error_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_import_error_endpoint.py
similarity index 98%
rename from 
providers/tests/fab/auth_manager/api_endpoints/test_import_error_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_import_error_endpoint.py
index 04bf4182ec3..91556957cc8 100644
--- 
a/providers/tests/fab/auth_manager/api_endpoints/test_import_error_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_import_error_endpoint.py
@@ -22,8 +22,8 @@ from airflow.dag_processing.bundles.manager import 
DagBundlesManager
 from airflow.models.dag import DagModel
 from airflow.providers.fab.www.security import permissions
 from airflow.utils import timezone
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 from tests_common.test_utils.compat import ParseImportError
 from tests_common.test_utils.db import clear_db_dags, clear_db_import_errors
 from tests_common.test_utils.permissions import _resource_name
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_role_and_permission_endpoint.py
 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_role_and_permission_endpoint.py
similarity index 99%
rename from 
providers/tests/fab/auth_manager/api_endpoints/test_role_and_permission_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_role_and_permission_endpoint.py
index 6e9840d72aa..b42fe8ae2ee 100644
--- 
a/providers/tests/fab/auth_manager/api_endpoints/test_role_and_permission_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_role_and_permission_endpoint.py
@@ -20,13 +20,13 @@ import pytest
 
 from airflow.providers.fab.www.api_connexion.exceptions import 
EXCEPTIONS_LINK_MAP
 from airflow.providers.fab.www.security import permissions
-
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
(
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import (
     create_role,
     create_user,
     delete_role,
     delete_user,
 )
+
 from tests_common.test_utils.api_connexion_utils import assert_401
 from tests_common.test_utils.compat import ignore_provider_compatibility_error
 
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_task_instance_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_task_instance_endpoint.py
similarity index 99%
rename from 
providers/tests/fab/auth_manager/api_endpoints/test_task_instance_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_task_instance_endpoint.py
index 24613fe7f2a..94e219ebcf0 100644
--- 
a/providers/tests/fab/auth_manager/api_endpoints/test_task_instance_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_task_instance_endpoint.py
@@ -28,12 +28,12 @@ from airflow.utils.session import provide_session
 from airflow.utils.state import State
 from airflow.utils.timezone import datetime
 from airflow.utils.types import DagRunType
-
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
(
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import (
     create_user,
     delete_roles,
     delete_user,
 )
+
 from tests_common.test_utils.db import clear_db_runs, clear_rendered_ti_fields
 from tests_common.test_utils.version_compat import AIRFLOW_V_3_0_PLUS
 
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_user_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_user_endpoint.py
similarity index 99%
rename from providers/tests/fab/auth_manager/api_endpoints/test_user_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_user_endpoint.py
index 063a29ec782..14285d4695f 100644
--- a/providers/tests/fab/auth_manager/api_endpoints/test_user_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_user_endpoint.py
@@ -25,12 +25,12 @@ from airflow.providers.fab.www.api_connexion.exceptions 
import EXCEPTIONS_LINK_M
 from airflow.providers.fab.www.security import permissions
 from airflow.utils import timezone
 from airflow.utils.session import create_session
-
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
(
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import (
     create_user,
     delete_role,
     delete_user,
 )
+
 from tests_common.test_utils.api_connexion_utils import assert_401
 from tests_common.test_utils.compat import ignore_provider_compatibility_error
 from tests_common.test_utils.config import conf_vars
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_variable_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_variable_endpoint.py
similarity index 96%
rename from 
providers/tests/fab/auth_manager/api_endpoints/test_variable_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_variable_endpoint.py
index fcf29ab1af9..89683265838 100644
--- a/providers/tests/fab/auth_manager/api_endpoints/test_variable_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_variable_endpoint.py
@@ -20,8 +20,8 @@ import pytest
 
 from airflow.models import Variable
 from airflow.providers.fab.www.security import permissions
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 from tests_common.test_utils.db import clear_db_variables
 from tests_common.test_utils.version_compat import AIRFLOW_V_3_0_PLUS
 
diff --git 
a/providers/tests/fab/auth_manager/api_endpoints/test_xcom_endpoint.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_xcom_endpoint.py
similarity index 98%
rename from providers/tests/fab/auth_manager/api_endpoints/test_xcom_endpoint.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_xcom_endpoint.py
index 85f40b7557c..6c3dd08b9e8 100644
--- a/providers/tests/fab/auth_manager/api_endpoints/test_xcom_endpoint.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/api_endpoints/test_xcom_endpoint.py
@@ -29,8 +29,8 @@ from airflow.providers.fab.www.security import permissions
 from airflow.utils import timezone
 from airflow.utils.session import create_session
 from airflow.utils.types import DagRunType
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
 from tests_common.test_utils.db import clear_db_dags, clear_db_runs, 
clear_db_xcom
 from tests_common.test_utils.version_compat import AIRFLOW_V_3_0_PLUS
 
diff --git a/providers/tests/fab/auth_manager/cli_commands/__init__.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/__init__.py
similarity index 100%
rename from providers/tests/fab/auth_manager/cli_commands/__init__.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/__init__.py
diff --git a/providers/tests/fab/auth_manager/cli_commands/test_db_command.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_db_command.py
similarity index 100%
rename from providers/tests/fab/auth_manager/cli_commands/test_db_command.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_db_command.py
diff --git a/providers/tests/fab/auth_manager/cli_commands/test_definition.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_definition.py
similarity index 100%
rename from providers/tests/fab/auth_manager/cli_commands/test_definition.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_definition.py
diff --git a/providers/tests/fab/auth_manager/cli_commands/test_role_command.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_role_command.py
similarity index 100%
rename from providers/tests/fab/auth_manager/cli_commands/test_role_command.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_role_command.py
diff --git 
a/providers/tests/fab/auth_manager/cli_commands/test_sync_perm_command.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_sync_perm_command.py
similarity index 100%
rename from 
providers/tests/fab/auth_manager/cli_commands/test_sync_perm_command.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_sync_perm_command.py
diff --git a/providers/tests/fab/auth_manager/cli_commands/test_user_command.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_user_command.py
similarity index 100%
rename from providers/tests/fab/auth_manager/cli_commands/test_user_command.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_user_command.py
diff --git a/providers/tests/fab/auth_manager/cli_commands/test_utils.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_utils.py
similarity index 100%
rename from providers/tests/fab/auth_manager/cli_commands/test_utils.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/cli_commands/test_utils.py
diff --git a/providers/tests/fab/auth_manager/conftest.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/conftest.py
similarity index 95%
rename from providers/tests/fab/auth_manager/conftest.py
rename to providers/fab/tests/provider_tests/fab/auth_manager/conftest.py
index ce73a3e0cd9..9c0f76f0306 100644
--- a/providers/tests/fab/auth_manager/conftest.py
+++ b/providers/fab/tests/provider_tests/fab/auth_manager/conftest.py
@@ -49,7 +49,7 @@ def minimal_app_for_auth_api():
                 (
                     "api",
                     "auth_backends",
-                ): 
"providers.tests.fab.auth_manager.api_endpoints.remote_user_api_auth_backend,airflow.providers.fab.auth_manager.api.auth.backend.session",
+                ): 
"provider_tests.fab.auth_manager.api_endpoints.remote_user_api_auth_backend,airflow.providers.fab.auth_manager.api.auth.backend.session",
                 (
                     "core",
                     "auth_manager",
diff --git a/providers/tests/fab/auth_manager/models/__init__.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/models/__init__.py
similarity index 100%
rename from providers/tests/fab/auth_manager/models/__init__.py
rename to providers/fab/tests/provider_tests/fab/auth_manager/models/__init__.py
diff --git a/providers/tests/fab/auth_manager/models/test_anonymous_user.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/models/test_anonymous_user.py
similarity index 100%
rename from providers/tests/fab/auth_manager/models/test_anonymous_user.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/models/test_anonymous_user.py
diff --git a/providers/tests/fab/auth_manager/models/test_db.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/models/test_db.py
similarity index 96%
rename from providers/tests/fab/auth_manager/models/test_db.py
rename to providers/fab/tests/provider_tests/fab/auth_manager/models/test_db.py
index 3af94ceed7b..91e14495713 100644
--- a/providers/tests/fab/auth_manager/models/test_db.py
+++ b/providers/fab/tests/provider_tests/fab/auth_manager/models/test_db.py
@@ -19,12 +19,12 @@ from __future__ import annotations
 import re
 from unittest import mock
 
+import providers.fab.src.airflow.providers.fab as provider_fab
 import pytest
 from alembic.autogenerate import compare_metadata
 from alembic.migration import MigrationContext
 from sqlalchemy import MetaData
 
-import airflow.providers
 from airflow.settings import engine
 from airflow.utils.db import (
     compare_server_default,
@@ -37,16 +37,16 @@ try:
 
     class TestFABDBManager:
         def setup_method(self):
-            self.providers_dir: str = airflow.providers.__path__[0]
+            self.providers_dir: str = provider_fab.__path__[0]
 
         def test_version_table_name_set(self, session):
             assert FABDBManager(session=session).version_table_name == 
"alembic_version_fab"
 
         def test_migration_dir_set(self, session):
-            assert FABDBManager(session=session).migration_dir == 
f"{self.providers_dir}/fab/migrations"
+            assert FABDBManager(session=session).migration_dir == 
f"{self.providers_dir}/migrations"
 
         def test_alembic_file_set(self, session):
-            assert FABDBManager(session=session).alembic_file == 
f"{self.providers_dir}/fab/alembic.ini"
+            assert FABDBManager(session=session).alembic_file == 
f"{self.providers_dir}/alembic.ini"
 
         def test_supports_table_dropping_set(self, session):
             assert FABDBManager(session=session).supports_table_dropping is 
True
@@ -128,5 +128,6 @@ try:
                 mock_initdb.assert_not_called()
             else:
                 mock_initdb.assert_called_once()
+
 except ModuleNotFoundError:
     pass
diff --git a/providers/tests/fab/auth_manager/schemas/__init__.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/schemas/__init__.py
similarity index 100%
rename from providers/tests/fab/auth_manager/schemas/__init__.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/schemas/__init__.py
diff --git 
a/providers/tests/fab/auth_manager/schemas/test_role_and_permission_schema.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/schemas/test_role_and_permission_schema.py
similarity index 97%
rename from 
providers/tests/fab/auth_manager/schemas/test_role_and_permission_schema.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/schemas/test_role_and_permission_schema.py
index 24a4de43176..457b244150f 100644
--- 
a/providers/tests/fab/auth_manager/schemas/test_role_and_permission_schema.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/schemas/test_role_and_permission_schema.py
@@ -24,8 +24,7 @@ from 
airflow.providers.fab.auth_manager.schemas.role_and_permission_schema impor
     role_schema,
 )
 from airflow.providers.fab.www.security import permissions
-
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_role, delete_role
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_role, delete_role
 
 pytestmark = pytest.mark.db_test
 
diff --git a/providers/tests/fab/auth_manager/schemas/test_user_schema.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/schemas/test_user_schema.py
similarity index 97%
rename from providers/tests/fab/auth_manager/schemas/test_user_schema.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/schemas/test_user_schema.py
index 87cdc42f4a3..735dc14056e 100644
--- a/providers/tests/fab/auth_manager/schemas/test_user_schema.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/schemas/test_user_schema.py
@@ -19,8 +19,8 @@ from __future__ import annotations
 import pytest
 
 from airflow.utils import timezone
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_role, delete_role
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_role, delete_role
 from tests_common.test_utils.compat import ignore_provider_compatibility_error
 
 with ignore_provider_compatibility_error("2.9.0+", __file__):
diff --git a/providers/tests/fab/auth_manager/security_manager/__init__.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/security_manager/__init__.py
similarity index 100%
rename from providers/tests/fab/auth_manager/security_manager/__init__.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/security_manager/__init__.py
diff --git 
a/providers/tests/fab/auth_manager/security_manager/test_constants.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/security_manager/test_constants.py
similarity index 100%
rename from providers/tests/fab/auth_manager/security_manager/test_constants.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/security_manager/test_constants.py
diff --git a/providers/tests/fab/auth_manager/security_manager/test_override.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/security_manager/test_override.py
similarity index 100%
rename from providers/tests/fab/auth_manager/security_manager/test_override.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/security_manager/test_override.py
diff --git a/providers/tests/fab/auth_manager/test_fab_auth_manager.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/test_fab_auth_manager.py
similarity index 99%
rename from providers/tests/fab/auth_manager/test_fab_auth_manager.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/test_fab_auth_manager.py
index 077350ac10c..1fef2598ba0 100644
--- a/providers/tests/fab/auth_manager/test_fab_auth_manager.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/test_fab_auth_manager.py
@@ -27,8 +27,7 @@ from flask import Flask, g
 from flask_appbuilder.menu import Menu
 
 from airflow.exceptions import AirflowConfigException, AirflowException
-
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user
 
 try:
     from airflow.auth.managers.models.resource_details import AccessView, 
DagAccessEntity, DagDetails
diff --git a/providers/tests/fab/auth_manager/test_models.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/test_models.py
similarity index 100%
rename from providers/tests/fab/auth_manager/test_models.py
rename to providers/fab/tests/provider_tests/fab/auth_manager/test_models.py
diff --git a/providers/tests/fab/auth_manager/test_security.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/test_security.py
similarity index 99%
rename from providers/tests/fab/auth_manager/test_security.py
rename to providers/fab/tests/provider_tests/fab/auth_manager/test_security.py
index 95c5545d878..b09674b599a 100644
--- a/providers/tests/fab/auth_manager/test_security.py
+++ b/providers/fab/tests/provider_tests/fab/auth_manager/test_security.py
@@ -50,14 +50,14 @@ from airflow.providers.fab.www.security.permissions import 
ACTION_CAN_READ
 from airflow.www import app as application
 from airflow.www.auth import get_access_denied_message
 from airflow.www.utils import CustomSQLAInterface
-
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
(
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import (
     create_user,
     create_user_scope,
     delete_role,
     delete_user,
     set_user_single_role,
 )
+
 from tests_common.test_utils.asserts import assert_queries_count
 from tests_common.test_utils.db import clear_db_dags, clear_db_runs
 from tests_common.test_utils.mock_security_manager import MockSecurityManager
diff --git a/providers/tests/fab/auth_manager/views/__init__.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/views/__init__.py
similarity index 100%
rename from providers/tests/fab/auth_manager/views/__init__.py
rename to providers/fab/tests/provider_tests/fab/auth_manager/views/__init__.py
diff --git a/providers/tests/fab/auth_manager/views/test_permissions.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/views/test_permissions.py
similarity index 93%
rename from providers/tests/fab/auth_manager/views/test_permissions.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/views/test_permissions.py
index b2eb0b47c5c..08c224bcb96 100644
--- a/providers/tests/fab/auth_manager/views/test_permissions.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/views/test_permissions.py
@@ -21,9 +21,9 @@ import pytest
 
 from airflow.providers.fab.www.security import permissions
 from airflow.www import app as application
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
+from provider_tests.fab.auth_manager.views import 
_assert_dataset_deprecation_warning
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
-from providers.tests.fab.auth_manager.views import 
_assert_dataset_deprecation_warning
 from tests_common.test_utils.www import client_with_login
 
 
diff --git a/providers/tests/fab/auth_manager/views/test_roles_list.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/views/test_roles_list.py
similarity index 91%
rename from providers/tests/fab/auth_manager/views/test_roles_list.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/views/test_roles_list.py
index e728b2ae328..3413dd44ce2 100644
--- a/providers/tests/fab/auth_manager/views/test_roles_list.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/views/test_roles_list.py
@@ -21,9 +21,9 @@ import pytest
 
 from airflow.providers.fab.www.security import permissions
 from airflow.www import app as application
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
+from provider_tests.fab.auth_manager.views import 
_assert_dataset_deprecation_warning
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
-from providers.tests.fab.auth_manager.views import 
_assert_dataset_deprecation_warning
 from tests_common.test_utils.www import client_with_login
 
 
diff --git a/providers/tests/fab/auth_manager/views/test_user.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/views/test_user.py
similarity index 91%
rename from providers/tests/fab/auth_manager/views/test_user.py
rename to providers/fab/tests/provider_tests/fab/auth_manager/views/test_user.py
index 7dadeeaf525..88b3844eb8b 100644
--- a/providers/tests/fab/auth_manager/views/test_user.py
+++ b/providers/fab/tests/provider_tests/fab/auth_manager/views/test_user.py
@@ -21,9 +21,9 @@ import pytest
 
 from airflow.providers.fab.www.security import permissions
 from airflow.www import app as application
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
+from provider_tests.fab.auth_manager.views import 
_assert_dataset_deprecation_warning
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
-from providers.tests.fab.auth_manager.views import 
_assert_dataset_deprecation_warning
 from tests_common.test_utils.www import client_with_login
 
 
diff --git a/providers/tests/fab/auth_manager/views/test_user_edit.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/views/test_user_edit.py
similarity index 91%
rename from providers/tests/fab/auth_manager/views/test_user_edit.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/views/test_user_edit.py
index afd2e537125..4f48bfb657f 100644
--- a/providers/tests/fab/auth_manager/views/test_user_edit.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/views/test_user_edit.py
@@ -21,9 +21,9 @@ import pytest
 
 from airflow.providers.fab.www.security import permissions
 from airflow.www import app as application
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
+from provider_tests.fab.auth_manager.views import 
_assert_dataset_deprecation_warning
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
-from providers.tests.fab.auth_manager.views import 
_assert_dataset_deprecation_warning
 from tests_common.test_utils.www import client_with_login
 
 
diff --git a/providers/tests/fab/auth_manager/views/test_user_stats.py 
b/providers/fab/tests/provider_tests/fab/auth_manager/views/test_user_stats.py
similarity index 91%
rename from providers/tests/fab/auth_manager/views/test_user_stats.py
rename to 
providers/fab/tests/provider_tests/fab/auth_manager/views/test_user_stats.py
index 1e08c94dfb7..ce0ba9c04aa 100644
--- a/providers/tests/fab/auth_manager/views/test_user_stats.py
+++ 
b/providers/fab/tests/provider_tests/fab/auth_manager/views/test_user_stats.py
@@ -21,9 +21,9 @@ import pytest
 
 from airflow.providers.fab.www.security import permissions
 from airflow.www import app as application
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
+from provider_tests.fab.auth_manager.views import 
_assert_dataset_deprecation_warning
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user, delete_user
-from providers.tests.fab.auth_manager.views import 
_assert_dataset_deprecation_warning
 from tests_common.test_utils.www import client_with_login
 
 
diff --git a/providers/src/airflow/providers/fab/auth_manager/__init__.py 
b/providers/fab/tests/provider_tests/fab/www/__init__.py
similarity index 100%
copy from providers/src/airflow/providers/fab/auth_manager/__init__.py
copy to providers/fab/tests/provider_tests/fab/www/__init__.py
diff --git a/providers/src/airflow/providers/fab/auth_manager/__init__.py 
b/providers/fab/tests/provider_tests/fab/www/views/__init__.py
similarity index 100%
rename from providers/src/airflow/providers/fab/auth_manager/__init__.py
rename to providers/fab/tests/provider_tests/fab/www/views/__init__.py
diff --git a/providers/fab/tests/provider_tests/fab/www/views/conftest.py 
b/providers/fab/tests/provider_tests/fab/www/views/conftest.py
new file mode 100644
index 00000000000..8b770afe965
--- /dev/null
+++ b/providers/fab/tests/provider_tests/fab/www/views/conftest.py
@@ -0,0 +1,124 @@
+#
+# Licensed to the Apache Software Foundation (ASF) under one
+# or more contributor license agreements.  See the NOTICE file
+# distributed with this work for additional information
+# regarding copyright ownership.  The ASF licenses this file
+# to you under the Apache License, Version 2.0 (the
+# "License"); you may not use this file except in compliance
+# with the License.  You may obtain a copy of the License at
+#
+#   http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing,
+# software distributed under the License is distributed on an
+# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+# KIND, either express or implied.  See the License for the
+# specific language governing permissions and limitations
+# under the License.
+from __future__ import annotations
+
+import os
+
+import jinja2
+import pytest
+from 
providers.fab.tests.provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils
 import delete_user
+
+from airflow import settings
+from airflow.models import DagBag
+from airflow.www.app import create_app
+
+from tests_common.test_utils.config import conf_vars
+from tests_common.test_utils.db import parse_and_sync_to_db
+from tests_common.test_utils.decorators import 
dont_initialize_flask_app_submodules
+from tests_common.test_utils.www import client_with_login
+
+
[email protected](autouse=True, scope="module")
+def session():
+    settings.configure_orm()
+    return settings.Session
+
+
[email protected](autouse=True, scope="module")
+def examples_dag_bag(session):
+    parse_and_sync_to_db(os.devnull, include_examples=True)
+    dag_bag = DagBag(read_dags_from_db=True)
+    session.commit()
+    return dag_bag
+
+
[email protected](scope="module")
+def app(examples_dag_bag):
+    @dont_initialize_flask_app_submodules(
+        skip_all_except=[
+            "init_api_connexion",
+            "init_appbuilder",
+            "init_appbuilder_links",
+            "init_appbuilder_views",
+            "init_flash_views",
+            "init_jinja_globals",
+            "init_plugins",
+            "init_airflow_session_interface",
+        ]
+    )
+    def factory():
+        with conf_vars({("fab", "auth_rate_limited"): "False"}):
+            return create_app(testing=True)
+
+    app = factory()
+    app.config["WTF_CSRF_ENABLED"] = False
+    app.dag_bag = examples_dag_bag
+    app.jinja_env.undefined = jinja2.StrictUndefined
+
+    security_manager = app.appbuilder.sm
+
+    test_users = [
+        {
+            "username": "test_admin",
+            "first_name": "test_admin_first_name",
+            "last_name": "test_admin_last_name",
+            "email": "[email protected]",
+            "role": security_manager.find_role("Admin"),
+            "password": "test_admin_password",
+        },
+        {
+            "username": "test_user",
+            "first_name": "test_user_first_name",
+            "last_name": "test_user_last_name",
+            "email": "[email protected]",
+            "role": security_manager.find_role("User"),
+            "password": "test_user_password",
+        },
+        {
+            "username": "test_viewer",
+            "first_name": "test_viewer_first_name",
+            "last_name": "test_viewer_last_name",
+            "email": "[email protected]",
+            "role": security_manager.find_role("Viewer"),
+            "password": "test_viewer_password",
+        },
+    ]
+
+    for user_dict in test_users:
+        if not security_manager.find_user(username=user_dict["username"]):
+            security_manager.add_user(**user_dict)
+
+    yield app
+
+    for user_dict in test_users:
+        delete_user(app, user_dict["username"])
+
+
[email protected]
+def user_client(app):
+    return client_with_login(app, username="test_user", password="test_user")
+
+
[email protected]
+def viewer_client(app):
+    return client_with_login(app, username="test_viewer", 
password="test_viewer")
+
+
[email protected]
+def admin_client(app):
+    return client_with_login(app, username="test_admin", password="test_admin")
diff --git a/tests/www/views/test_views_acl.py 
b/providers/fab/tests/provider_tests/fab/www/views/test_views_acl.py
similarity index 99%
rename from tests/www/views/test_views_acl.py
rename to providers/fab/tests/provider_tests/fab/www/views/test_views_acl.py
index c28026973eb..290afe7c737 100644
--- a/tests/www/views/test_views_acl.py
+++ b/providers/fab/tests/provider_tests/fab/www/views/test_views_acl.py
@@ -30,8 +30,8 @@ from airflow.utils.session import create_session
 from airflow.utils.state import State
 from airflow.utils.types import DagRunType
 from airflow.www.views import FILTER_STATUS_COOKIE
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user_scope
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user_scope
 from tests_common.test_utils.db import clear_db_runs
 from tests_common.test_utils.permissions import _resource_name
 from tests_common.test_utils.version_compat import AIRFLOW_V_3_0_PLUS
diff --git a/tests/www/views/test_views_custom_user_views.py 
b/providers/fab/tests/provider_tests/fab/www/views/test_views_custom_user_views.py
similarity index 99%
rename from tests/www/views/test_views_custom_user_views.py
rename to 
providers/fab/tests/provider_tests/fab/www/views/test_views_custom_user_views.py
index e3f7f3e5ccc..cb2cb8bbeb3 100644
--- a/tests/www/views/test_views_custom_user_views.py
+++ 
b/providers/fab/tests/provider_tests/fab/www/views/test_views_custom_user_views.py
@@ -27,11 +27,11 @@ from flask_appbuilder import SQLA
 from airflow import settings
 from airflow.security import permissions
 from airflow.www import app as application
-
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
(
+from provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils import (
     create_user,
     delete_role,
 )
+
 from tests_common.test_utils.www import (
     check_content_in_response,
     check_content_not_in_response,
diff --git a/pyproject.toml b/pyproject.toml
index 483896cf1a2..3314bd1b209 100644
--- a/pyproject.toml
+++ b/pyproject.toml
@@ -649,6 +649,7 @@ dev = [
   "apache-airflow-providers-edge",
   "apache-airflow-providers-elasticsearch",
   "apache-airflow-providers-exasol",
+  "apache-airflow-providers-fab",
   "apache-airflow-providers-facebook",
   "apache-airflow-providers-ftp",
   "apache-airflow-providers-github",
@@ -727,6 +728,7 @@ apache-airflow-providers-docker = { workspace = true }
 apache-airflow-providers-edge = {workspace = true}
 apache-airflow-providers-elasticsearch = { workspace = true }
 apache-airflow-providers-exasol = { workspace = true }
+apache-airflow-providers-fab = { workspace = true }
 apache-airflow-providers-facebook = { workspace = true }
 apache-airflow-providers-ftp = { workspace = true }
 apache-airflow-providers-github = { workspace = true }
@@ -803,6 +805,7 @@ members = [
     "providers/edge",
     "providers/elasticsearch",
     "providers/exasol",
+    "providers/fab",
     "providers/facebook",
     "providers/ftp",
     "providers/github",
diff --git a/scripts/ci/docker-compose/remove-sources.yml 
b/scripts/ci/docker-compose/remove-sources.yml
index bacf05e198a..c2f9b4b8ea7 100644
--- a/scripts/ci/docker-compose/remove-sources.yml
+++ b/scripts/ci/docker-compose/remove-sources.yml
@@ -60,6 +60,7 @@ services:
       - ../../../empty:/opt/airflow/providers/edge/src
       - ../../../empty:/opt/airflow/providers/elasticsearch/src
       - ../../../empty:/opt/airflow/providers/exasol/src
+      - ../../../empty:/opt/airflow/providers/fab/src
       - ../../../empty:/opt/airflow/providers/facebook/src
       - ../../../empty:/opt/airflow/providers/ftp/src
       - ../../../empty:/opt/airflow/providers/github/src
diff --git a/scripts/ci/docker-compose/tests-sources.yml 
b/scripts/ci/docker-compose/tests-sources.yml
index a39bcf25b5e..d5495d20aba 100644
--- a/scripts/ci/docker-compose/tests-sources.yml
+++ b/scripts/ci/docker-compose/tests-sources.yml
@@ -67,6 +67,7 @@ services:
       - ../../../providers/edge/tests:/opt/airflow/providers/edge/tests
       - 
../../../providers/elasticsearch/tests:/opt/airflow/providers/elasticsearch/tests
       - ../../../providers/exasol/tests:/opt/airflow/providers/exasol/tests
+      - ../../../providers/fab/tests:/opt/airflow/providers/fab/tests
       - ../../../providers/facebook/tests:/opt/airflow/providers/facebook/tests
       - ../../../providers/ftp/tests:/opt/airflow/providers/ftp/tests
       - ../../../providers/github/tests:/opt/airflow/providers/github/tests
diff --git a/scripts/ci/pre_commit/version_heads_map.py 
b/scripts/ci/pre_commit/version_heads_map.py
index 6796819444d..229d384a6e3 100755
--- a/scripts/ci/pre_commit/version_heads_map.py
+++ b/scripts/ci/pre_commit/version_heads_map.py
@@ -29,7 +29,7 @@ PROJECT_SOURCE_ROOT_DIR = 
Path(__file__).resolve().parent.parent.parent.parent
 DB_FILE = PROJECT_SOURCE_ROOT_DIR / "airflow" / "utils" / "db.py"
 MIGRATION_PATH = PROJECT_SOURCE_ROOT_DIR / "airflow" / "migrations" / 
"versions"
 
-PROVIDERS_SRC = PROJECT_SOURCE_ROOT_DIR / "providers" / "src"
+PROVIDERS_SRC = PROJECT_SOURCE_ROOT_DIR / "providers" / "fab" / "src"
 FAB_DB_FILE = PROVIDERS_SRC / "airflow" / "providers" / "fab" / "auth_manager" 
/ "models" / "db.py"
 FAB_MIGRATION_PATH = PROVIDERS_SRC / "airflow" / "providers" / "fab" / 
"migrations" / "versions"
 
diff --git a/scripts/in_container/run_migration_reference.py 
b/scripts/in_container/run_migration_reference.py
index 086eb0aa336..939022f6e9b 100755
--- a/scripts/in_container/run_migration_reference.py
+++ b/scripts/in_container/run_migration_reference.py
@@ -155,7 +155,7 @@ def update_docs(revisions: Iterable[Script], app="airflow"):
             )
         )
     if app == "fab":
-        filepath = project_root / "docs" / "apache-airflow-providers-fab" / 
"migrations-ref.rst"
+        filepath = project_root / "providers" / "fab" / "docs" / 
"migrations-ref.rst"
     else:
         filepath = project_root / "docs" / "apache-airflow" / 
"migrations-ref.rst"
 
diff --git a/tests/www/views/test_views_dagrun.py 
b/tests/www/views/test_views_dagrun.py
index 12f375b870e..b6bb3f3751d 100644
--- a/tests/www/views/test_views_dagrun.py
+++ b/tests/www/views/test_views_dagrun.py
@@ -25,12 +25,12 @@ from airflow.utils import timezone
 from airflow.utils.session import create_session
 from airflow.utils.types import DagRunType
 from airflow.www.views import DagRunModelView
-
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
(
+from 
providers.fab.tests.provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils
 import (
     create_user,
     delete_roles,
     delete_user,
 )
+
 from tests.www.views.test_views_tasks import _get_appbuilder_pk_string
 from tests_common.test_utils.version_compat import AIRFLOW_V_3_0_PLUS
 from tests_common.test_utils.www import (
diff --git a/tests/www/views/test_views_home.py 
b/tests/www/views/test_views_home.py
index ae0e2c3e5d7..58689e6925a 100644
--- a/tests/www/views/test_views_home.py
+++ b/tests/www/views/test_views_home.py
@@ -27,8 +27,8 @@ from airflow.security import permissions
 from airflow.utils.state import State
 from airflow.www.utils import UIAlert
 from airflow.www.views import FILTER_LASTRUN_COOKIE, FILTER_STATUS_COOKIE, 
FILTER_TAGS_COOKIE
+from 
providers.fab.tests.provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils
 import create_user
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user
 from tests_common.test_utils.db import clear_db_dags, clear_db_import_errors, 
clear_db_serialized_dags
 from tests_common.test_utils.permissions import _resource_name
 from tests_common.test_utils.www import (
diff --git a/tests/www/views/test_views_tasks.py 
b/tests/www/views/test_views_tasks.py
index 3efb0a13189..7cb0de9024c 100644
--- a/tests/www/views/test_views_tasks.py
+++ b/tests/www/views/test_views_tasks.py
@@ -41,12 +41,12 @@ from airflow.utils.session import create_session
 from airflow.utils.state import DagRunState, State
 from airflow.utils.types import DagRunType
 from airflow.www.views import TaskInstanceModelView, _safe_parse_datetime
-
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
(
+from 
providers.fab.tests.provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils
 import (
     create_user,
     delete_roles,
     delete_user,
 )
+
 from tests_common.test_utils.compat import BashOperator
 from tests_common.test_utils.config import conf_vars
 from tests_common.test_utils.db import clear_db_runs, clear_db_xcom
diff --git a/tests/www/views/test_views_trigger_dag.py 
b/tests/www/views/test_views_trigger_dag.py
index c4136520d7f..bcd80ed555b 100644
--- a/tests/www/views/test_views_trigger_dag.py
+++ b/tests/www/views/test_views_trigger_dag.py
@@ -32,8 +32,10 @@ from airflow.utils import timezone
 from airflow.utils.json import WebEncoder
 from airflow.utils.session import create_session
 from airflow.utils.types import DagRunType
+from 
providers.fab.tests.provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils
 import (
+    create_test_client,
+)
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_test_client
 from tests_common.test_utils.config import conf_vars
 from tests_common.test_utils.www import check_content_in_response
 
diff --git a/tests/www/views/test_views_variable.py 
b/tests/www/views/test_views_variable.py
index f085d5021a8..c426632da23 100644
--- a/tests/www/views/test_views_variable.py
+++ b/tests/www/views/test_views_variable.py
@@ -25,8 +25,8 @@ import pytest
 from airflow.models import Variable
 from airflow.security import permissions
 from airflow.utils.session import create_session
+from 
providers.fab.tests.provider_tests.fab.auth_manager.api_endpoints.api_connexion_utils
 import create_user
 
-from providers.tests.fab.auth_manager.api_endpoints.api_connexion_utils import 
create_user
 from tests_common.test_utils.www import (
     _check_last_log,
     check_content_in_response,

Reply via email to