| Airflow 2.2.2, 2021-11-15 |
| ------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| - Fix bug when checking for existence of a Variable (#19395) |
| - Fix Serialization when ``relativedelta`` is passed as ``schedule_interval`` (#19418) |
| - Fix moving of dangling TaskInstance rows for SQL Server (#19425) |
| - Fix task instance modal in gantt view (#19258) |
| - Fix serialization of ``Params`` with set data type (#19267) |
| - Check if job object is ``None`` before calling ``.is_alive()`` (#19380) |
| - Task should fail immediately when pod is unprocessable (#19359) |
| - Fix downgrade for a DB Migration (#19390) |
| - Only mark SchedulerJobs as failed, not any jobs (#19375) |
| - Fix message on "Mark as" confirmation page (#19363) |
| - Bugfix: Check next run exists before reading data interval (#19307) |
| - Fix MySQL db migration with default encoding/collation (#19268) |
| - Fix hidden tooltip position (#19261) |
| - ``sqlite_default`` Connection has been hard-coded to ``/tmp``, use ``gettempdir`` instead (#19255) |
| - Fix Toggle Wrap on DAG code page (#19211) |
| - Clarify "dag not found" error message in CLI (#19338) |
| - Add Note to SLA regarding ``schedule_interval`` (#19173) |
| - Use ``execution_date`` to check for existing ``DagRun`` for ``TriggerDagRunOperator`` (#18968) |
| - Add explicit session parameter in ``PoolSlotsAvailableDep`` (#18875) |
| - FAB still requires ``WTForms<3.0`` (#19466) |
| - Fix missing dagruns when ``catchup=True`` (#19528) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - Add missing parameter documentation for "timetable" (#19282) |
| - Improve Kubernetes Executor docs (#19339) |
| - Update image tag used in docker docs |
| |
| Airflow 2.2.1, 2021-10-29 |
| ------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| - Fix Unexpected commit error in schedulerjob (#19213) |
| - Add DagRun.logical_date as a property (#19198) |
| - Clear ``ti.next_method`` and ``ti.next_kwargs`` on task finish (#19183) |
| - Faster PostgreSQL db migration to Airflow 2.2 (#19166) |
| - Remove incorrect type comment in ``Swagger2Specification._set_defaults`` classmethod (#19065) |
| - Add TriggererJob to jobs check command (#19179, #19185) |
| - Hide tooltip when next run is ``None`` (#19112) |
| - Create TI context with data interval compat layer (#19148) |
| - Fix queued dag runs changes ``catchup=False`` behaviour (#19130, #19145) |
| - add detailed information to logging when a dag or a task finishes. (#19097) |
| - Warn about unsupported Python 3.10 (#19060) |
| - Fix catchup by limiting queued dagrun creation using ``max_active_runs`` (#18897) |
| - Prevent scheduler crash when serialized dag is missing (#19113) |
| - Don't install SQLAlchemy/Pendulum adapters for other DBs (#18745) |
| - Workaround libstdcpp TLS error (#19010) |
| - Change ``ds``, ``ts``, etc. back to use logical date (#19088) |
| - Ensure task state doesn't change when marked as failed/success/skipped (#19095) |
| - Relax packaging requirement (#19087) |
| - Rename trigger page label to Logical Date (#19061) |
| - Allow Param to support a default value of ``None`` (#19034) |
| - Upgrade old DAG/task param format when deserializing from the DB (#18986) |
| - Don't bake ENV and _cmd into tmp config for non-sudo (#18772) |
| - CLI: Fail ``backfill`` command before loading DAGs if missing args (#18994) |
| - BugFix: Null execution date on insert to ``task_fail`` violating NOT NULL (#18979) |
| - Try to move "dangling" rows in upgradedb (#18953) |
| - Row lock TI query in ``SchedulerJob._process_executor_events`` (#18975) |
| - Sentry before send fallback (#18980) |
| - Fix ``XCom.delete`` error in Airflow 2.2.0 (#18956) |
| - Check python version before starting triggerer (#18926) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - Update access control documentation for TaskInstances and DagRuns (#18644) |
| - Add information about keepalives for managed Postgres (#18850) |
| - Doc: Add Callbacks Section to Logging & Monitoring (#18842) |
| - Group PATCH DAGrun together with other DAGRun endpoints (#18885) |
| |
| Airflow 2.2.0, 2021-10-11 |
| ------------------------- |
| |
| New Features |
| """""""""""" |
| |
| - AIP-39: Add (customizable) Timetable class to Airflow for richer scheduling behaviour (#15397, #16030, |
| #16352, #17030, #17122, #17414, #17552, #17755, #17989, #18084, #18088, #18244, #18266, #18420, #18434, |
| #18421, #18475, #18499, #18573, #18522, #18729, #18706, #18742, #18786, #18804) |
| - AIP-40: Add Deferrable "Async" Tasks (#15389, #17564, #17565, #17601, #17745, #17747, #17748, #17875, |
| #17876, #18129, #18210, #18214, #18552, #18728, #18414) |
| - Add a Docker Taskflow decorator (#15330, #18739) |
| - Add Airflow Standalone command (#15826) |
| - Display alert messages on dashboard from local settings (#18284) |
| - Advanced Params using json-schema (#17100) |
| - Ability to test connections from UI or API (#15795, #18750) |
| - Add Next Run to UI (#17732) |
| - Add default weight rule configuration option (#18627) |
| - Add a calendar field to choose the execution date of the DAG when triggering it (#16141) |
| - Allow setting specific ``cwd`` for BashOperator (#17751) |
| - Show import errors in DAG views (#17818) |
| - Add pre/post execution hooks [Experimental] (#17576) |
| - Added table to view providers in Airflow ui under admin tab (#15385) |
| - Adds secrets backend/logging/auth information to provider yaml (#17625) |
| - Add date format filters to Jinja environment (#17451) |
| - Introduce ``RESTARTING`` state (#16681) |
| - Webserver: Unpause DAG on manual trigger (#16569) |
| - API endpoint to create new user (#16609) |
| - Add ``insert_args`` for support transfer replace (#15825) |
| - Add recursive flag to glob in filesystem sensor (#16894) |
| - Add conn to jinja template context (#16686) |
| - Add ``default_args`` for ``TaskGroup`` (#16557) |
| - Allow adding duplicate connections from UI (#15574) |
| - Allow specifying multiple URLs via the CORS config option (#17941) |
| - Implement API endpoint for DAG deletion (#17980) |
| - Add DAG run endpoint for marking a dagrun success or failed(#17839) |
| - Add support for ``kinit`` options ``[-f|-F]`` and ``[-a|-A]`` (#17816) |
| - Queue support for ``DaskExecutor`` using Dask Worker Resources (#16829, #18720) |
| - Make auto refresh interval configurable (#18107) |
| |
| Improvements |
| """""""""""" |
| - Small improvements for Airflow UI (#18715, #18795) |
| - Rename ``processor_poll_interval`` to ``scheduler_idle_sleep_time`` (#18704) |
| - Check the allowed values for the logging level (#18651) |
| - Fix error on triggering a dag that doesn't exist using ``dagrun_conf`` (#18655) |
| - Add muldelete action to ``TaskInstanceModelView`` (#18438) |
| - Avoid importing DAGs during clean DB installation (#18450) |
| - Require can_edit on DAG privileges to modify TaskInstances and DagRuns (#16634) |
| - Make Kubernetes job description fit on one log line (#18377) |
| - Always draw borders if task instance state is null or undefined (#18033) |
| - Inclusive Language (#18349) |
| - Improved log handling for zombie tasks (#18277) |
| - Adding ``Variable.update`` method and improving detection of variable key collisions (#18159) |
| - Add note about params on trigger DAG page (#18166) |
| - Change ``TaskInstance`` and ``TaskReschedule`` PK from ``execution_date`` to ``run_id`` (#17719) |
| - Adding ``TaskGroup`` support in ``BaseOperator.chain()`` (#17456) |
| - Allow filtering DAGS by tags in the REST API (#18090) |
| - Optimize imports of Providers Manager (#18052) |
| - Adds capability of Warnings for incompatible community providers (#18020) |
| - Serialize the ``template_ext`` attribute to show it in UI (#17985) |
| - Add ``robots.txt`` and ``X-Robots-Tag`` header (#17946) |
| - Refactor ``BranchDayOfWeekOperator``, ``DayOfWeekSensor`` (#17940) |
| - Update error message to guide the user into self-help mostly (#17929) |
| - Update to Celery 5 (#17397) |
| - Add links to provider's documentation (#17736) |
| - Remove Marshmallow schema warnings (#17753) |
| - Rename ``none_failed_or_skipped`` by ``none_failed_min_one_success`` trigger rule (#17683) |
| - Remove ``[core] store_dag_code`` & use DB to get Dag Code (#16342) |
| - Rename ``task_concurrency`` to ``max_active_tis_per_dag`` (#17708) |
| - Import Hooks lazily individually in providers manager (#17682) |
| - Adding support for multiple task-ids in the external task sensor (#17339) |
| - Replace ``execution_date`` with ``run_id`` in airflow tasks run command (#16666) |
| - Make output from users cli command more consistent (#17642) |
| - Open relative extra links in place (#17477) |
| - Move ``worker_log_server_port`` option to the logging section (#17621) |
| - Use gunicorn to serve logs generated by worker (#17591) |
| - Improve validation of Group id (#17578) |
| - Simplify 404 page (#17501) |
| - Add XCom.clear so it's hookable in custom XCom backend (#17405) |
| - Add deprecation notice for ``SubDagOperator`` (#17488) |
| - Support DAGS folder being in different location on scheduler and runners (#16860) |
| - Remove /dagrun/create and disable edit form generated by F.A.B (#17376) |
| - Enable specifying dictionary paths in ``template_fields_renderers`` (#17321) |
| - error early if virtualenv is missing (#15788) |
| - Handle connection parameters added to Extra and custom fields (#17269) |
| - Fix ``airflow celery stop`` to accept the pid file. (#17278) |
| - Remove DAG refresh buttons (#17263) |
| - Deprecate dummy trigger rule in favor of always (#17144) |
| - Be verbose about failure to import ``airflow_local_settings`` (#17195) |
| - Include exit code in ``AirflowException`` str when ``BashOperator`` fails. (#17151) |
| - Adding EdgeModifier support for chain() (#17099) |
| - Only allows supported field types to be used in custom connections (#17194) |
| - Secrets backend failover (#16404) |
| - Warn on Webserver when using ``SQLite`` or ``SequentialExecutor`` (#17133) |
| - Extend ``init_containers`` defined in ``pod_override`` (#17537) |
| - Client-side filter dag dependencies (#16253) |
| - Improve executor validation in CLI (#17071) |
| - Prevent running ``airflow db init/upgrade`` migrations and setup in parallel. (#17078) |
| - Update ``chain()`` and ``cross_downstream()`` to support ``XComArgs`` (#16732) |
| - Improve graph view refresh (#16696) |
| - When a task instance fails with exception, log it (#16805) |
| - Set process title for ``serve-logs`` and ``LocalExecutor`` (#16644) |
| - Rename ``test_cycle`` to ``check_cycle`` (#16617) |
| - Add schema as ``DbApiHook`` instance attribute (#16521, #17423) |
| - Improve compatibility with MSSQL (#9973) |
| - Add transparency for unsupported connection type (#16220) |
| - Call resource based fab methods (#16190) |
| - Format more dates with timezone (#16129) |
| - Replace deprecated ``dag.sub_dag`` with ``dag.partial_subset`` (#16179) |
| - Treat ``AirflowSensorTimeout`` as immediate failure without retrying (#12058) |
| - Marking success/failed automatically clears failed downstream tasks (#13037) |
| - Add close/open indicator for import dag errors (#16073) |
| - Add collapsible import errors (#16072) |
| - Always return a response in TI's ``action_clear`` view (#15980) |
| - Add cli command to delete user by email (#15873) |
| - Use resource and action names for FAB permissions (#16410) |
| - Rename DAG concurrency (``[core] dag_concurrency``) settings for easier understanding (#16267, #18730) |
| - Calendar UI improvements (#16226) |
| - Refactor: ``SKIPPED`` should not be logged again as ``SUCCESS`` (#14822) |
| - Remove version limits for dnspython (#18046, #18162) |
| - Accept custom run ID in TriggerDagRunOperator (#18788) |
| |
| Bug Fixes |
| """"""""" |
| - Make REST API patch user endpoint work the same way as the UI (#18757) |
| - Properly set ``start_date`` for cleared tasks (#18708) |
| - Ensure task_instance exists before running update on its state(REST API) (#18642) |
| - Make ``AirflowDateTimePickerWidget`` a required field (#18602) |
| - Retry deadlocked transactions on deleting old rendered task fields (#18616) |
| - Fix `retry_exponential_backoff` divide by zero error when retry delay is zero (#17003) |
| - Improve how UI handles datetimes (#18611, #18700) |
| - Bugfix: dag_bag.get_dag should return None, not raise exception (#18554) |
| - Only show the task modal if it is a valid instance (#18570) |
| - Fix accessing rendered ``{{ task.x }}`` attributes from within templates (#18516) |
| - Add missing email type of connection (#18502) |
| - Don't use flash for "same-page" UI messages. (#18462) |
| - Fix task group tooltip (#18406) |
| - Properly fix dagrun update state endpoint (#18370) |
| - Properly handle ti state difference between executor and scheduler (#17819) |
| - Fix stuck "queued" tasks in KubernetesExecutor (#18152) |
| - Don't permanently add zip DAGs to ``sys.path`` (#18384) |
| - Fix random deadlocks in MSSQL database (#18362) |
| - Deactivating DAGs which have been removed from files (#17121) |
| - When syncing dags to db remove ``dag_tag`` rows that are now unused (#8231) |
| - Graceful scheduler shutdown on error (#18092) |
| - Fix mini scheduler not respecting ``wait_for_downstream`` dep (#18338) |
| - Pass exception to ``run_finished_callback`` for Debug Executor (#17983) |
| - Make ``XCom.get_one`` return full, not abbreviated values (#18274) |
| - Use try/except when closing temporary file in task_runner (#18269) |
| - show next run if not none (#18273) |
| - Fix DB session handling in ``XCom.set`` (#18240) |
| - Fix external_executor_id not being set for manually run jobs (#17207) |
| - Fix deleting of zipped Dags in Serialized Dag Table (#18243) |
| - Return explicit error on user-add for duplicated email (#18224) |
| - Remove loading dots even when last run data is empty (#18230) |
| - Swap dag import error dropdown icons (#18207) |
| - Automatically create section when migrating config (#16814) |
| - Set encoding to utf-8 by default while reading task logs (#17965) |
| - Apply parent dag permissions to subdags (#18160) |
| - Change id collation for MySQL to case-sensitive (#18072) |
| - Logs task launch exception in ``StandardTaskRunner`` (#17967) |
| - Applied permissions to ``self._error_file`` (#15947) |
| - Fix blank dag dependencies view (#17990) |
| - Add missing menu access for dag dependencies and configurations pages (#17450) |
| - Fix passing Jinja templates in ``DateTimeSensor`` (#17959) |
| - Fixing bug which restricted the visibility of ImportErrors (#17924) |
| - Fix grammar in ``traceback.html`` (#17942) |
| - Fix ``DagRunState`` enum query for ``MySQLdb`` driver (#17886) |
| - Fixed button size in "Actions" group. (#17902) |
| - Only show import errors for DAGs a user can access (#17835) |
| - Show all import_errors from zip files (#17759) |
| - fix EXTRA_LOGGER_NAMES param and related docs (#17808) |
| - Use one interpreter for Airflow and gunicorn (#17805) |
| - Fix: Mysql 5.7 id utf8mb3 (#14535) |
| - Fix dag_processing.last_duration metric random holes (#17769) |
| - Automatically use ``utf8mb3_general_ci`` collation for MySQL (#17729) |
| - fix: filter condition of ``TaskInstance`` does not work #17535 (#17548) |
| - Dont use TaskInstance in CeleryExecutor.trigger_tasks (#16248) |
| - Remove locks for upgrades in MSSQL (#17213) |
| - Create virtualenv via python call (#17156) |
| - Ensure a DAG is acyclic when running ``DAG.cli()`` (#17105) |
| - Translate non-ascii characters (#17057) |
| - Change the logic of ``None`` comparison in ``model_list`` template (#16893) |
| - Have UI and POST /task_instances_state API endpoint have same behaviour (#16539) |
| - ensure task is skipped if missing sla (#16719) |
| - Fix direct use of ``cached_property`` module (#16710) |
| - Fix TI success confirm page (#16650) |
| - Modify return value check in python virtualenv jinja template (#16049) |
| - Fix dag dependency search (#15924) |
| - Make custom JSON encoder support ``Decimal`` (#16383) |
| - Bugfix: Allow clearing tasks with just ``dag_id`` and empty ``subdir`` (#16513) |
| - Convert port value to a number before calling test connection (#16497) |
| - Handle missing/null serialized DAG dependencies (#16393) |
| - Correctly set ``dag.fileloc`` when using the ``@dag`` decorator (#16384) |
| - Fix TI success/failure links (#16233) |
| - Correctly implement autocomplete early return in ``airflow/www/views.py`` (#15940) |
| - Backport fix to allow pickling of Loggers to Python 3.6 (#18798) |
| - Fix bug that Backfill job fail to run when there are tasks run into ``reschedule`` state (#17305, #18806) |
| |
| Doc only changes |
| """""""""""""""" |
| - Update ``dagbag_size`` documentation (#18824) |
| - Update documentation about bundle extras (#18828) |
| - Fix wrong Postgres ``search_path`` set up instructions (#17600) |
| - Remove ``AIRFLOW_GID`` from Docker images (#18747) |
| - Improve error message for BranchPythonOperator when no task_id to follow (#18471) |
| - Improve guidance to users telling them what to do on import timeout (#18478) |
| - Explain scheduler fine-tuning better (#18356) |
| - Added example JSON for airflow pools import (#18376) |
| - Add ``sla_miss_callback`` section to the documentation (#18305) |
| - Explain sentry default environment variable for subprocess hook (#18346) |
| - Refactor installation pages (#18282) |
| - Improves quick-start docker-compose warnings and documentation (#18164) |
| - Production-level support for MSSQL (#18382) |
| - Update non-working example in documentation (#18067) |
| - Remove default_args pattern + added get_current_context() use for Core Airflow example DAGs (#16866) |
| - Update max_tis_per_query to better render on the webpage (#17971) |
| - Adds Github Oauth example with team based authorization (#17896) |
| - Update docker.rst (#17882) |
| - Example xcom update (#17749) |
| - Add doc warning about connections added via envvars (#17915) |
| - fix wrong documents around upgrade-check.rst (#17903) |
| - Add Brent to Committers list (#17873) |
| - Improves documentation about modules management (#17757) |
| - Remove deprecated metrics from metrics.rst (#17772) |
| - Make sure "production-readiness" of docker-compose is well explained (#17731) |
| - Doc: Update Upgrade to v2 docs with Airflow 1.10.x EOL dates (#17710) |
| - Doc: Replace deprecated param from docstrings (#17709) |
| - docs(dagowner): describe dag owner more carefully (#17699) |
| - docs(impersonation): update note so avoid misintrepretation (#17701) |
| - Docs: Make ``DAG.is_active`` read-only in API (#17667) |
| - Update documentation regarding Python 3.9 support (#17611) |
| - Fix MySQL database character set instruction (#17603) |
| - Document overriding ``XCom.clear`` for data lifecycle management (#17589) |
| - Path correction in docs for airflow core (#17567) |
| - docs(celery): reworded, add actual multiple queues example (#17541) |
| - Doc: Add FAQ to speed up parsing with tons of dag files (#17519) |
| - Improve image building documentation for new users (#17409) |
| - Doc: Strip unnecessary arguments from MariaDB JIRA URL (#17296) |
| - Update warning about MariaDB and multiple schedulers (#17287) |
| - Doc: Recommend using same configs on all Airflow components (#17146) |
| - Move docs about masking to a new page (#17007) |
| - Docs: Suggest use of Env vars instead of Airflow Vars in best practises doc (#16926) |
| - Docs: Better description for ``pod_template_file`` (#16861) |
| - Add Aneesh Joseph as Airflow Committer (#16835) |
| - Docs: Added new pipeline example for the tutorial docs (#16548) |
| - Remove upstart from docs (#16672) |
| - Add new committers: ``Jed`` and ``TP`` (#16671) |
| - Docs: Fix ``flask-ouathlib`` to ``flask-oauthlib`` in Upgrading docs (#16320) |
| - Docs: Fix creating a connection docs (#16312) |
| - Docs: Fix url for ``Elasticsearch`` (#16275) |
| - Small improvements for README.md files (#16244) |
| - Fix docs for ``dag_concurrency`` (#16177) |
| - Check syntactic correctness for code-snippets (#16005) |
| - Add proper link for wheel packages in docs. (#15999) |
| - Add Docs for ``default_pool`` slots (#15997) |
| - Add memory usage warning in quick-start documentation (#15967) |
| - Update example ``KubernetesExecutor`` ``git-sync`` pod template file (#15904) |
| - Docs: Fix Taskflow API docs (#16574) |
| - Added new pipeline example for the tutorial docs (#16084) |
| - Updating the DAG docstring to include ``render_template_as_native_obj`` (#16534) |
| - Update docs on setting up SMTP (#16523) |
| - Docs: Fix API verb from ``POST`` to ``PATCH`` (#16511) |
| |
| Misc/Internal |
| """"""""""""" |
| - Renaming variables to be consistent with code logic (#18685) |
| - Simplify strings previously split across lines (#18679) |
| - fix exception string of ``BranchPythonOperator`` (#18623) |
| - Add multiple roles when creating users (#18617) |
| - Move FABs base Security Manager into Airflow. (#16647) |
| - Remove unnecessary css state colors (#18461) |
| - Update ``boto3`` to ``<1.19`` (#18389) |
| - Improve coverage for ``airflow.security.kerberos module`` (#18258) |
| - Fix kinesis test (#18337) |
| - Fix provider test accessing importlib-resources (#18228) |
| - Silence warnings in tests from using SubDagOperator (#18275) |
| - Fix usage of ``range(len())`` to ``enumerate`` (#18174) |
| - Test coverage on the autocomplete view (#15943) |
| - Add "packaging" to core requirements (#18122) |
| - Adds LoggingMixins to BaseTrigger (#18106) |
| - Fix building docs in ``main`` builds (#18035) |
| - Remove upper-limit on ``tenacity`` (#17593) |
| - Remove redundant ``numpy`` dependency (#17594) |
| - Bump ``mysql-connector-python`` to latest version (#17596) |
| - Make ``pandas`` an optional core dependency (#17575) |
| - Add more typing to airflow.utils.helpers (#15582) |
| - Chore: Some code cleanup in ``airflow/utils/db.py`` (#17090) |
| - Refactor: Remove processor_factory from DAG processing (#16659) |
| - Remove AbstractDagFileProcessorProcess from dag processing (#16816) |
| - Update TaskGroup typing (#16811) |
| - Update ``click`` to 8.x (#16779) |
| - Remove remaining Pylint disables (#16760) |
| - Remove duplicated try, there is already a try in create_session (#16701) |
| - Removes pylint from our toolchain (#16682) |
| - Refactor usage of unneeded function call (#16653) |
| - Add type annotations to setup.py (#16658) |
| - Remove SQLAlchemy <1.4 constraint (#16630) (Note: our dependencies still have a requirement on <1.4) |
| - Refactor ``dag.clear`` method (#16086) |
| - Use ``DAG_ACTIONS`` constant (#16232) |
| - Use updated ``_get_all_non_dag_permissions`` method (#16317) |
| - Add updated-name wrappers for built-in FAB methods (#16077) |
| - Remove ``TaskInstance.log_filepath`` attribute (#15217) |
| - Removes unnecessary function call in ``airflow/www/app.py`` (#15956) |
| - Move ``plyvel`` to google provider extra (#15812) |
| - Update permission migrations to use new naming scheme (#16400) |
| - Use resource and action names for FAB (#16380) |
| - Swap out calls to ``find_permission_view_menu`` for ``get_permission`` wrapper (#16377) |
| - Fix deprecated default for ``fab_logging_level`` to ``WARNING`` (#18783) |
| - Allow running tasks from UI when using ``CeleryKubernetesExecutor`` (#18441) |
| |
| Airflow 2.1.4, 2021-09-18 |
| ------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| - Fix deprecation error message rather than silencing it (#18126) |
| - Limit the number of queued dagruns created by the Scheduler (#18065) |
| - Fix ``DagRun`` execution order from queued to running not being properly followed (#18061) |
| - Fix ``max_active_runs`` not allowing moving of queued dagruns to running (#17945) |
| - Avoid redirect loop for users with no permissions (#17838) |
| - Avoid endless redirect loop when user has no roles (#17613) |
| - Fix log links on graph TI modal (#17862) |
| - Hide variable import form if user lacks permission (#18000) |
| - Improve dag/task concurrency check (#17786) |
| - Fix Clear task instances endpoint resets all DAG runs bug (#17961) |
| - Fixes incorrect parameter passed to views (#18083) (#18085) |
| - Fix Sentry handler from ``LocalTaskJob`` causing error (#18119) |
| - Limit ``colorlog`` version (6.x is incompatible) (#18099) |
| - Only show Pause/Unpause tooltip on hover (#17957) |
| - Improve graph view load time for dags with open groups (#17821) |
| - Increase width for Run column (#17817) |
| - Fix wrong query on running tis (#17631) |
| - Add root to tree refresh url (#17633) |
| - Do not delete running DAG from the UI (#17630) |
| - Improve discoverability of Provider packages' functionality |
| - Do not let ``create_dagrun`` overwrite explicit ``run_id`` (#17728) |
| - Regression on pid reset to allow task start after heartbeat (#17333) |
| - Set task state to failed when pod is DELETED while running (#18095) |
| - Advises the kernel to not cache log files generated by Airflow (#18054) |
| - Sort adopted tasks in ``_check_for_stalled_adopted_tasks`` method (#18208) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - Update version added fields in airflow/config_templates/config.yml (#18128) |
| - Improve the description of how to handle dynamic task generation (#17963) |
| - Improve cross-links to operators and hooks references (#17622) |
| - Doc: Fix replacing Airflow version for Docker stack (#17711) |
| - Make the providers operators/hooks reference much more usable (#17768) |
| - Update description about the new ``connection-types`` provider meta-data |
| - Suggest to use secrets backend for variable when it contains sensitive data (#17319) |
| - Separate Installing from sources section and add more details (#18171) |
| - Doc: Use ``closer.lua`` script for downloading sources (#18179) |
| - Doc: Improve installing from sources (#18194) |
| - Improves installing from sources pages for all components (#18251) |
| |
| Airflow 2.1.3, 2021-08-23 |
| ------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| - Fix task retries when they receive ``sigkill`` and have retries and properly handle ``sigterm`` (#16301) |
| - Fix redacting secrets in context exceptions. (#17618) |
| - Fix race condition with dagrun callbacks (#16741) |
| - Add 'queued' to DagRunState (#16854) |
| - Add 'queued' state to DagRun (#16401) |
| - Fix external elasticsearch logs link (#16357) |
| - Add proper warning message when recorded PID is different from current PID (#17411) |
| - Fix running tasks with ``default_impersonation`` config (#17229) |
| - Rescue if a DagRun's DAG was removed from db (#17544) |
| - Fixed broken json_client (#17529) |
| - Handle and log exceptions raised during task callback (#17347) |
| - Fix CLI ``kubernetes cleanup-pods`` which fails on invalid label key (#17298) |
| - Show serialization exceptions in DAG parsing log (#17277) |
| - Fix: ``TaskInstance`` does not show ``queued_by_job_id`` & ``external_executor_id`` (#17179) |
| - Adds more explanatory message when ``SecretsMasker`` is not configured (#17101) |
| - Enable the use of ``__init_subclass__`` in subclasses of ``BaseOperator`` (#17027) |
| - Fix task instance retrieval in XCom view (#16923) |
| - Validate type of ``priority_weight`` during parsing (#16765) |
| - Correctly handle custom ``deps` and ``task_group`` during DAG Serialization (#16734) |
| - Fix slow (cleared) tasks being be adopted by Celery worker. (#16718) |
| - Fix calculating duration in tree view (#16695) |
| - Fix ``AttributeError``: ``datetime.timezone`` object has no attribute ``name`` (#16599) |
| - Redact conn secrets in webserver logs (#16579) |
| - Change graph focus to top of view instead of center (#16484) |
| - Fail tasks in scheduler when executor reports they failed (#15929) |
| - fix(smart_sensor): Unbound variable errors (#14774) |
| - Add back missing permissions to ``UserModelView`` controls. (#17431) |
| - Better diagnostics and self-healing of docker-compose (#17484) |
| - Improve diagnostics message when users have ``secret_key`` mis-configured (#17410) |
| - Stop checking ``execution_date`` in ``task_instance.refresh_from_db`` (#16809) |
| |
| Improvements |
| """""""""""" |
| |
| - Run mini scheduler in ``LocalTaskJob`` during task exit (#16289) |
| - Remove ``SQLAlchemy<1.4`` constraint (#16630) |
| - Bump Jinja2 upper-bound from 2.12.0 to 4.0.0 (#16595) |
| - Bump ``dnspython`` (#16698) |
| - Updates to ``FlaskAppBuilder`` 3.3.2+ (#17208) |
| - Add State types for tasks and DAGs (#15285) |
| - Set Process title for Worker when using ``LocalExecutor`` (#16623) |
| - Move ``DagFileProcessor`` and ``DagFileProcessorProcess`` out of ``scheduler_job.py`` (#16581) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - Fix inconsistencies in configuration docs (#17317) |
| - Fix docs link for using SQLite as Metadata DB (#17308) |
| |
| Misc |
| """" |
| |
| - Switch back http provider after requests removes LGPL dependency (#16974) |
| |
| Airflow 2.1.2, 2021-07-14 |
| ------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| - Only allow webserver to request from the worker log server (#16754) |
| - Fix "Invalid JSON configuration, must be a dict" bug (#16648) |
| - Fix ``CeleryKubernetesExecutor`` (#16700) |
| - Mask value if the key is ``token`` (#16474) |
| - Fix impersonation issue with ``LocalTaskJob`` (#16852) |
| - Resolve all npm vulnerabilities including bumping ``jQuery`` to ``3.5`` (#16440) |
| |
| Misc |
| """" |
| |
| - Add Python 3.9 support (#15515) |
| |
| |
| Airflow 2.1.1, 2021-07-02 |
| ------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| - Don't crash attempting to mask secrets in dict with non-string keys (#16601) |
| - Always install sphinx_airflow_theme from ``PyPI`` (#16594) |
| - Remove limitation for elasticsearch library (#16553) |
| - Adding extra requirements for build and runtime of the PROD image. (#16170) |
| - Cattrs 1.7.0 released by the end of May 2021 break lineage usage (#16173) |
| - Removes unnecessary packages from setup_requires (#16139) |
| - Pins docutils to <0.17 until breaking behaviour is fixed (#16133) |
| - Improvements for Docker Image docs (#14843) |
| - Ensure that ``dag_run.conf`` is a dict (#15057) |
| - Fix CLI connections import and migrate logic from secrets to Connection model (#15425) |
| - Fix Dag Details start date bug (#16206) |
| - Fix DAG run state not updated while DAG is paused (#16343) |
| - Allow null value for operator field in task_instance schema(REST API) (#16516) |
| - Avoid recursion going too deep when redacting logs (#16491) |
| - Backfill: Don't create a DagRun if no tasks match task regex (#16461) |
| - Tree View UI for larger DAGs & more consistent spacing in Tree View (#16522) |
| - Correctly handle None returns from Query.scalar() (#16345) |
| - Adding ``only_active`` parameter to /dags endpoint (#14306) |
| - Don't show stale Serialized DAGs if they are deleted in DB (#16368) |
| - Make REST API List DAGs endpoint consistent with UI/CLI behaviour (#16318) |
| - Support remote logging in elasticsearch with ``filebeat 7`` (#14625) |
| - Queue tasks with higher priority and earlier execution_date first. (#15210) |
| - Make task ID on legend have enough width and width of line chart to be 100%. (#15915) |
| - Fix normalize-url vulnerability (#16375) |
| - Validate retries value on init for better errors (#16415) |
| - add num_runs query param for tree refresh (#16437) |
| - Fix templated default/example values in config ref docs (#16442) |
| - Add ``passphrase`` and ``private_key`` to default sensitive field names (#16392) |
| - Fix tasks in an infinite slots pool were never scheduled (#15247) |
| - Fix Orphaned tasks stuck in CeleryExecutor as running (#16550) |
| - Don't fail to log if we can't redact something (#16118) |
| - Set max tree width to 1200 pixels (#16067) |
| - Fill the "job_id" field for ``airflow task run`` without ``--local``/``--raw`` for KubeExecutor (#16108) |
| - Fixes problem where conf variable was used before initialization (#16088) |
| - Fix apply defaults for task decorator (#16085) |
| - Parse recently modified files even if just parsed (#16075) |
| - Ensure that we don't try to mask empty string in logs (#16057) |
| - Don't die when masking ``log.exception`` when there is no exception (#16047) |
| - Restores apply_defaults import in base_sensor_operator (#16040) |
| - Fix auto-refresh in tree view When webserver ui is not in ``/`` (#16018) |
| - Fix dag.clear() to set multiple dags to running when necessary (#15382) |
| - Fix Celery executor getting stuck randomly because of reset_signals in multiprocessing (#15989) |
| |
| |
| Airflow 2.1.0, 2021-05-21 |
| ------------------------- |
| |
| New Features |
| """""""""""" |
| |
| - Add ``PythonVirtualenvDecorator`` to Taskflow API (#14761) |
| - Add ``Taskgroup`` decorator (#15034) |
| - Create a DAG Calendar View (#15423) |
| - Create cross-DAG dependencies view (#13199) |
| - Add rest API to query for providers (#13394) |
| - Mask passwords and sensitive info in task logs and UI (#15599) |
| - Add ``SubprocessHook`` for running commands from operators (#13423) |
| - Add DAG Timeout in UI page "DAG Details" (#14165) |
| - Add ``WeekDayBranchOperator`` (#13997) |
| - Add JSON linter to DAG Trigger UI (#13551) |
| - Add DAG Description Doc to Trigger UI Page (#13365) |
| - Add airflow webserver URL into SLA miss email. (#13249) |
| - Add read only REST API endpoints for users (#14735) |
| - Add files to generate Airflow's Python SDK (#14739) |
| - Add dynamic fields to snowflake connection (#14724) |
| - Add read only REST API endpoint for roles and permissions (#14664) |
| - Add new datetime branch operator (#11964) |
| - Add Google leveldb hook and operator (#13109) (#14105) |
| - Add plugins endpoint to the REST API (#14280) |
| - Add ``worker_pod_pending_timeout`` support (#15263) |
| - Add support for labeling DAG edges (#15142) |
| - Add CUD REST API endpoints for Roles (#14840) |
| - Import connections from a file (#15177) |
| - A bunch of ``template_fields_renderers`` additions (#15130) |
| - Add REST API query sort and order to some endpoints (#14895) |
| - Add timezone context in new ui (#15096) |
| - Add query mutations to new UI (#15068) |
| - Add different modes to sort dag files for parsing (#15046) |
| - Auto refresh on Tree View (#15474) |
| - BashOperator to raise ``AirflowSkipException`` on exit code 99 (by default, configurable) (#13421) (#14963) |
| - Clear tasks by task ids in REST API (#14500) |
| - Support jinja2 native Python types (#14603) |
| - Allow celery workers without gossip or mingle modes (#13880) |
| - Add ``airflow jobs check`` CLI command to check health of jobs (Scheduler etc) (#14519) |
| - Rename ``DateTimeBranchOperator`` to ``BranchDateTimeOperator`` (#14720) |
| |
| Improvements |
| """""""""""" |
| |
| - Add optional result handler callback to ``DbApiHook`` (#15581) |
| - Update Flask App Builder limit to recently released 3.3 (#15792) |
| - Prevent creating flask sessions on REST API requests (#15295) |
| - Sync DAG specific permissions when parsing (#15311) |
| - Increase maximum length of pool name on Tasks to 256 characters (#15203) |
| - Enforce READ COMMITTED isolation when using mysql (#15714) |
| - Auto-apply ``apply_default`` to subclasses of ``BaseOperator`` (#15667) |
| - Emit error on duplicated DAG ID (#15302) |
| - Update ``KubernetesExecutor`` pod templates to allow access to IAM permissions (#15669) |
| - More verbose logs when running ``airflow db check-migrations`` (#15662) |
| - When one_success mark task as failed if no success (#15467) |
| - Add an option to trigger a dag w/o changing conf (#15591) |
| - Add Airflow UI instance_name configuration option (#10162) |
| - Add a decorator to retry functions with DB transactions (#14109) |
| - Add return to PythonVirtualenvOperator's execute method (#14061) |
| - Add verify_ssl config for kubernetes (#13516) |
| - Add description about ``secret_key`` when Webserver > 1 (#15546) |
| - Add Traceback in LogRecord in ``JSONFormatter`` (#15414) |
| - Add support for arbitrary json in conn uri format (#15100) |
| - Adds description field in variable (#12413) (#15194) |
| - Add logs to show last modified in SFTP, FTP and Filesystem sensor (#15134) |
| - Execute ``on_failure_callback`` when SIGTERM is received (#15172) |
| - Allow hiding of all edges when highlighting states (#15281) |
| - Display explicit error in case UID has no actual username (#15212) |
| - Serve logs with Scheduler when using Local or Sequential Executor (#15557) |
| - Deactivate trigger, refresh, and delete controls on dag detail view. (#14144) |
| - Turn off autocomplete for connection forms (#15073) |
| - Increase default ``worker_refresh_interval`` to ``6000`` seconds (#14970) |
| - Only show User's local timezone if it's not UTC (#13904) |
| - Suppress LOG/WARNING for a few tasks CLI for better CLI experience (#14567) |
| - Configurable API response (CORS) headers (#13620) |
| - Allow viewers to see all docs links (#14197) |
| - Update Tree View date ticks (#14141) |
| - Make the tooltip to Pause / Unpause a DAG clearer (#13642) |
| - Warn about precedence of env var when getting variables (#13501) |
| - Move ``[celery] default_queue`` config to ``[operators] default_queue`` to re-use between executors (#14699) |
| |
| Bug Fixes |
| """"""""" |
| |
| - Fix 500 error from ``updateTaskInstancesState`` API endpoint when ``dry_run`` not passed (#15889) |
| - Ensure that task preceding a PythonVirtualenvOperator doesn't fail (#15822) |
| - Prevent mixed case env vars from crashing processes like worker (#14380) |
| - Fixed type annotations in DAG decorator (#15778) |
| - Fix on_failure_callback when task receive SIGKILL (#15537) |
| - Fix dags table overflow (#15660) |
| - Fix changing the parent dag state on subdag clear (#15562) |
| - Fix reading from zip package to default to text (#13962) |
| - Fix wrong parameter for ``drawDagStatsForDag`` in dags.html (#13884) |
| - Fix QueuedLocalWorker crashing with EOFError (#13215) |
| - Fix typo in ``NotPreviouslySkippedDep`` (#13933) |
| - Fix parallelism after KubeExecutor pod adoption (#15555) |
| - Fix kube client on mac with keepalive enabled (#15551) |
| - Fixes wrong limit for dask for python>3.7 (should be <3.7) (#15545) |
| - Fix Task Adoption in ``KubernetesExecutor`` (#14795) |
| - Fix timeout when using XCom with ``KubernetesPodOperator`` (#15388) |
| - Fix deprecated provider aliases in "extras" not working (#15465) |
| - Fixed default XCom deserialization. (#14827) |
| - Fix used_group_ids in ``dag.partial_subset`` (#13700) (#15308) |
| - Further fix trimmed ``pod_id`` for ``KubernetesPodOperator`` (#15445) |
| - Bugfix: Invalid name when trimmed `pod_id` ends with hyphen in ``KubernetesPodOperator`` (#15443) |
| - Fix incorrect slots stats when TI ``pool_slots > 1`` (#15426) |
| - Fix DAG last run link (#15327) |
| - Fix ``sync-perm`` to work correctly when update_fab_perms = False (#14847) |
| - Fixes limits on Arrow for plexus test (#14781) |
| - Fix UI bugs in tree view (#14566) |
| - Fix AzureDataFactoryHook failing to instantiate its connection (#14565) |
| - Fix permission error on non-POSIX filesystem (#13121) |
| - Fix spelling in "ignorable" (#14348) |
| - Fix get_context_data doctest import (#14288) |
| - Correct typo in ``GCSObjectsWtihPrefixExistenceSensor`` (#14179) |
| - Fix order of failed deps (#14036) |
| - Fix critical ``CeleryKubernetesExecutor`` bug (#13247) |
| - Fix four bugs in ``StackdriverTaskHandler`` (#13784) |
| - ``func.sum`` may return ``Decimal`` that break rest APIs (#15585) |
| - Persist tags params in pagination (#15411) |
| - API: Raise ``AlreadyExists`` exception when the ``execution_date`` is same (#15174) |
| - Remove duplicate call to ``sync_metadata`` inside ``DagFileProcessorManager`` (#15121) |
| - Extra ``docker-py`` update to resolve docker op issues (#15731) |
| - Ensure executors end method is called (#14085) |
| - Remove ``user_id`` from API schema (#15117) |
| - Prevent clickable bad links on disabled pagination (#15074) |
| - Acquire lock on db for the time of migration (#10151) |
| - Skip SLA check only if SLA is None (#14064) |
| - Print right version in airflow info command (#14560) |
| - Make ``airflow info`` work with pipes (#14528) |
| - Rework client-side script for connection form. (#14052) |
| - API: Add ``CollectionInfo`` in all Collections that have ``total_entries`` (#14366) |
| - Fix ``task_instance_mutation_hook`` when importing airflow.models.dagrun (#15851) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - Fix docstring of SqlSensor (#15466) |
| - Small changes on "DAGs and Tasks documentation" (#14853) |
| - Add note on changes to configuration options (#15696) |
| - Add docs to the ``markdownlint`` and ``yamllint`` config files (#15682) |
| - Rename old "Experimental" API to deprecated in the docs. (#15653) |
| - Fix documentation error in `git_sync_template.yaml` (#13197) |
| - Fix doc link permission name (#14972) |
| - Fix link to Helm chart docs (#14652) |
| - Fix docstrings for Kubernetes code (#14605) |
| - docs: Capitalize & minor fixes (#14283) (#14534) |
| - Fixed reading from zip package to default to text. (#13984) |
| - An initial rework of the "Concepts" docs (#15444) |
| - Improve docstrings for various modules (#15047) |
| - Add documentation on database connection URI (#14124) |
| - Add Helm Chart logo to docs index (#14762) |
| - Create a new documentation package for Helm Chart (#14643) |
| - Add docs about supported logging levels (#14507) |
| - Update docs about tableau and salesforce provider (#14495) |
| - Replace deprecated doc links to the correct one (#14429) |
| - Refactor redundant doc url logic to use utility (#14080) |
| - docs: NOTICE: Updated 2016-2019 to 2016-now (#14248) |
| - Skip DAG perm sync during parsing if possible (#15464) |
| - Add picture and examples for Edge Labels (#15310) |
| - Add example DAG & how-to guide for sqlite (#13196) |
| - Add links to new modules for deprecated modules (#15316) |
| - Add note in Updating.md about FAB data model change (#14478) |
| |
| Misc/Internal |
| """"""""""""" |
| |
| - Fix ``logging.exception`` redundancy (#14823) |
| - Bump ``stylelint`` to remove vulnerable sub-dependency (#15784) |
| - Add resolution to force dependencies to use patched version of lodash (#15777) |
| - Update croniter to 1.0.x series (#15769) |
| - Get rid of Airflow 1.10 in Breeze (#15712) |
| - Run helm chart tests in parallel (#15706) |
| - Bump ``ssri`` from 6.0.1 to 6.0.2 in /airflow/www (#15437) |
| - Remove the limit on Gunicorn dependency (#15611) |
| - Better "dependency already registered" warning message for tasks #14613 (#14860) |
| - Pin pandas-gbq to <0.15.0 (#15114) |
| - Use Pip 21.* to install airflow officially (#15513) |
| - Bump mysqlclient to support the 1.4.x and 2.x series (#14978) |
| - Finish refactor of DAG resource name helper (#15511) |
| - Refactor/Cleanup Presentation of Graph Task and Path Highlighting (#15257) |
| - Standardize default fab perms (#14946) |
| - Remove ``datepicker`` for task instance detail view (#15284) |
| - Turn provider's import warnings into debug logs (#14903) |
| - Remove left-over fields from required in provider_info schema. (#14119) |
| - Deprecate ``tableau`` extra (#13595) |
| - Use built-in `cached_property` on Python 3.8 where possible (#14606) |
| - Clean-up JS code in UI templates (#14019) |
| - Bump elliptic from 6.5.3 to 6.5.4 in /airflow/www (#14668) |
| - Switch to f-strings using ``flynt``. (#13732) |
| - use ``jquery`` ready instead of vanilla js (#15258) |
| - Migrate task instance log (ti_log) js (#15309) |
| - Migrate graph js (#15307) |
| - Migrate dags.html javascript (#14692) |
| - Removes unnecessary AzureContainerInstance connection type (#15514) |
| - Separate Kubernetes pod_launcher from core airflow (#15165) |
| - update remaining old import paths of operators (#15127) |
| - Remove broken and undocumented "demo mode" feature (#14601) |
| - Simplify configuration/legibility of ``Webpack`` entries (#14551) |
| - remove inline tree js (#14552) |
| - Js linting and inline migration for simple scripts (#14215) |
| - Remove use of repeated constant in AirflowConfigParser (#14023) |
| - Deprecate email credentials from environment variables. (#13601) |
| - Remove unused 'context' variable in task_instance.py (#14049) |
| - Disable suppress_logs_and_warning in cli when debugging (#13180) |
| |
| |
| Airflow 2.0.2, 2021-04-19 |
| ------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| * Bugfix: ``TypeError`` when Serializing & sorting iterable properties of DAGs (#15395) |
| * Fix missing ``on_load`` trigger for folder-based plugins (#15208) |
| * ``kubernetes cleanup-pods`` subcommand will only clean up Airflow-created Pods (#15204) |
| * Fix password masking in CLI action_logging (#15143) |
| * Fix url generation for TriggerDagRunOperatorLink (#14990) |
| * Restore base lineage backend (#14146) |
| * Unable to trigger backfill or manual jobs with Kubernetes executor. (#14160) |
| * Bugfix: Task docs are not shown in the Task Instance Detail View (#15191) |
| * Bugfix: Fix overriding ``pod_template_file`` in KubernetesExecutor (#15197) |
| * Bugfix: resources in ``executor_config`` breaks Graph View in UI (#15199) |
| * Fix celery executor bug trying to call len on map (#14883) |
| * Fix bug in airflow.stats timing that broke dogstatsd mode (#15132) |
| * Avoid scheduler/parser manager deadlock by using non-blocking IO (#15112) |
| * Re-introduce ``dagrun.schedule_delay`` metric (#15105) |
| * Compare string values, not if strings are the same object in Kube executor(#14942) |
| * Pass queue to BaseExecutor.execute_async like in airflow 1.10 (#14861) |
| * Scheduler: Remove TIs from starved pools from the critical path. (#14476) |
| * Remove extra/needless deprecation warnings from airflow.contrib module (#15065) |
| * Fix support for long dag_id and task_id in KubernetesExecutor (#14703) |
| * Sort lists, sets and tuples in Serialized DAGs (#14909) |
| * Simplify cleaning string passed to origin param (#14738) (#14905) |
| * Fix error when running tasks with Sentry integration enabled. (#13929) |
| * Webserver: Sanitize string passed to origin param (#14738) |
| * Fix losing duration < 1 secs in tree (#13537) |
| * Pin SQLAlchemy to <1.4 due to breakage of sqlalchemy-utils (#14812) |
| * Fix KubernetesExecutor issue with deleted pending pods (#14810) |
| * Default to Celery Task model when backend model does not exist (#14612) |
| * Bugfix: Plugins endpoint was unauthenticated (#14570) |
| * BugFix: fix DAG doc display (especially for TaskFlow DAGs) (#14564) |
| * BugFix: TypeError in airflow.kubernetes.pod_launcher's monitor_pod (#14513) |
| * Bugfix: Fix wrong output of tags and owners in dag detail API endpoint (#14490) |
| * Fix logging error with task error when JSON logging is enabled (#14456) |
| * Fix statsd metrics not sending when using daemon mode (#14454) |
| * Gracefully handle missing start_date and end_date for DagRun (#14452) |
| * BugFix: Serialize max_retry_delay as a timedelta (#14436) |
| * Fix crash when user clicks on "Task Instance Details" caused by start_date being None (#14416) |
| * BugFix: Fix TaskInstance API call fails if a task is removed from running DAG (#14381) |
| * Scheduler should not fail when invalid ``executor_config`` is passed (#14323) |
| * Fix bug allowing task instances to survive when dagrun_timeout is exceeded (#14321) |
| * Fix bug where DAG timezone was not always shown correctly in UI tooltips (#14204) |
| * Use ``Lax`` for ``cookie_samesite`` when empty string is passed (#14183) |
| * [AIRFLOW-6076] fix ``dag.cli()`` KeyError (#13647) |
| * Fix running child tasks in a subdag after clearing a successful subdag (#14776) |
| |
| Improvements |
| """""""""""" |
| |
| * Remove unused JS packages causing false security alerts (#15383) |
| * Change default of ``[kubernetes] enable_tcp_keepalive`` for new installs to ``True`` (#15338) |
| * Fixed #14270: Add error message in OOM situations (#15207) |
| * Better compatibility/diagnostics for arbitrary UID in docker image (#15162) |
| * Updates 3.6 limits for latest versions of a few libraries (#15209) |
| * Adds Blinker dependency which is missing after recent changes (#15182) |
| * Remove 'conf' from search_columns in DagRun View (#15099) |
| * More proper default value for namespace in K8S cleanup-pods CLI (#15060) |
| * Faster default role syncing during webserver start (#15017) |
| * Speed up webserver start when there are many DAGs (#14993) |
| * Much easier to use and better documented Docker image (#14911) |
| * Use ``libyaml`` C library when available. (#14577) |
| * Don't create unittest.cfg when not running in unit test mode (#14420) |
| * Webserver: Allow Filtering TaskInstances by queued_dttm (#14708) |
| * Update Flask-AppBuilder dependency to allow 3.2 (and all 3.x series) (#14665) |
| * Remember expanded task groups in browser local storage (#14661) |
| * Add plain format output to cli tables (#14546) |
| * Make ``airflow dags show`` command display TaskGroups (#14269) |
| * Increase maximum size of ``extra`` connection field. (#12944) |
| * Speed up clear_task_instances by doing a single sql delete for TaskReschedule (#14048) |
| * Add more flexibility with FAB menu links (#13903) |
| * Add better description and guidance in case of sqlite version mismatch (#14209) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| * Add documentation create/update community providers (#15061) |
| * Fix mistake and typos in airflow.utils.timezone docstrings (#15180) |
| * Replace new url for Stable Airflow Docs (#15169) |
| * Docs: Clarify behavior of delete_worker_pods_on_failure (#14958) |
| * Create a documentation package for Docker image (#14846) |
| * Multiple minor doc (OpenAPI) fixes (#14917) |
| * Replace Graph View Screenshot to show Auto-refresh (#14571) |
| |
| Misc/Internal |
| """"""""""""" |
| |
| * Import Connection lazily in hooks to avoid cycles (#15361) |
| * Rename last_scheduler_run into last_parsed_time, and ensure it's updated in DB (#14581) |
| * Make TaskInstance.pool_slots not nullable with a default of 1 (#14406) |
| * Log migrations info in consistent way (#14158) |
| |
| Airflow 2.0.1, 2021-02-08 |
| ------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| - Bugfix: Return XCom Value in the XCom Endpoint API (#13684) |
| - Bugfix: Import error when using custom backend and ``sql_alchemy_conn_secret`` (#13260) |
| - Allow PID file path to be relative when daemonize a process (scheduler, kerberos, etc) (#13232) |
| - Bugfix: no generic ``DROP CONSTRAINT`` in MySQL during ``airflow db upgrade`` (#13239) |
| - Bugfix: Sync Access Control defined in DAGs when running ``sync-perm`` (#13377) |
| - Stop sending Callback Requests if no callbacks are defined on DAG (#13163) |
| - BugFix: Dag-level Callback Requests were not run (#13651) |
| - Stop creating duplicate Dag File Processors (#13662) |
| - Filter DagRuns with Task Instances in removed State while Scheduling (#13165) |
| - Bump ``datatables.net`` from 1.10.21 to 1.10.22 in /airflow/www (#13143) |
| - Bump ``datatables.net`` JS to 1.10.23 (#13253) |
| - Bump ``dompurify`` from 2.0.12 to 2.2.6 in /airflow/www (#13164) |
| - Update minimum ``cattrs`` version (#13223) |
| - Remove inapplicable arg 'output' for CLI pools import/export (#13071) |
| - Webserver: Fix the behavior to deactivate the authentication option and add docs (#13191) |
| - Fix: add support for no-menu plugin views (#11742) |
| - Add ``python-daemon`` limit for Python 3.8+ to fix daemon crash (#13540) |
| - Change the default celery ``worker_concurrency`` to 16 (#13612) |
| - Audit Log records View should not contain link if ``dag_id`` is None (#13619) |
| - Fix invalid ``continue_token`` for cleanup list pods (#13563) |
| - Switches to latest version of snowflake connector (#13654) |
| - Fix backfill crash on task retry or reschedule (#13712) |
| - Setting ``max_tis_per_query`` to ``0`` now correctly removes the limit (#13512) |
| - Fix race conditions in task callback invocations (#10917) |
| - Fix webserver exiting when gunicorn master crashes (#13518)(#13780) |
| - Fix SQL syntax to check duplicate connections (#13783) |
| - ``BaseBranchOperator`` will push to xcom by default (#13704) (#13763) |
| - Fix Deprecation for ``configuration.getsection`` (#13804) |
| - Fix TaskNotFound in log endpoint (#13872) |
| - Fix race condition when using Dynamic DAGs (#13893) |
| - Fix: Linux/Chrome window bouncing in Webserver |
| - Fix db shell for sqlite (#13907) |
| - Only compare updated time when Serialized DAG exists (#13899) |
| - Fix dag run type enum query for mysqldb driver (#13278) |
| - Add authentication to lineage endpoint for experimental API (#13870) |
| - Do not add User role perms to custom roles. (#13856) |
| - Do not add ``Website.can_read`` access to default roles. (#13923) |
| - Fix invalid value error caused by long Kubernetes pod name (#13299) |
| - Fix DB Migration for SQLite to upgrade to 2.0 (#13921) |
| - Bugfix: Manual DagRun trigger should not skip scheduled runs (#13963) |
| - Stop loading Extra Operator links in Scheduler (#13932) |
| - Added missing return parameter in read function of ``FileTaskHandler`` (#14001) |
| - Bugfix: Do not try to create a duplicate Dag Run in Scheduler (#13920) |
| - Make ``v1/config`` endpoint respect webserver ``expose_config`` setting (#14020) |
| - Disable row level locking for Mariadb and MySQL <8 (#14031) |
| - Bugfix: Fix permissions to triggering only specific DAGs (#13922) |
| - Fix broken SLA Mechanism (#14056) |
| - Bugfix: Scheduler fails if task is removed at runtime (#14057) |
| - Remove permissions to read Configurations for User and Viewer roles (#14067) |
| - Fix DB Migration from 2.0.1rc1 |
| |
| Improvements |
| """""""""""" |
| |
| - Increase the default ``min_file_process_interval`` to decrease CPU Usage (#13664) |
| - Dispose connections when running tasks with ``os.fork`` & ``CeleryExecutor`` (#13265) |
| - Make function purpose clearer in ``example_kubernetes_executor`` example dag (#13216) |
| - Remove unused libraries - ``flask-swagger``, ``funcsigs`` (#13178) |
| - Display alternative tooltip when a Task has yet to run (no TI) (#13162) |
| - User werkzeug's own type conversion for request args (#13184) |
| - UI: Add ``queued_by_job_id`` & ``external_executor_id`` Columns to TI View (#13266) |
| - Make ``json-merge-patch`` an optional library and unpin it (#13175) |
| - Adds missing LDAP "extra" dependencies to ldap provider. (#13308) |
| - Refactor ``setup.py`` to better reflect changes in providers (#13314) |
| - Pin ``pyjwt`` and Add integration tests for Apache Pinot (#13195) |
| - Removes provider-imposed requirements from ``setup.cfg`` (#13409) |
| - Replace deprecated decorator (#13443) |
| - Streamline & simplify ``__eq__`` methods in models Dag and BaseOperator (#13449) |
| - Additional properties should be allowed in provider schema (#13440) |
| - Remove unused dependency - ``contextdecorator`` (#13455) |
| - Remove 'typing' dependency (#13472) |
| - Log migrations info in consistent way (#13458) |
| - Unpin ``mysql-connector-python`` to allow ``8.0.22`` (#13370) |
| - Remove thrift as a core dependency (#13471) |
| - Add ``NotFound`` response for DELETE methods in OpenAPI YAML (#13550) |
| - Stop Log Spamming when ``[core] lazy_load_plugins`` is ``False`` (#13578) |
| - Display message and docs link when no plugins are loaded (#13599) |
| - Unpin restriction for ``colorlog`` dependency (#13176) |
| - Add missing Dag Tag for Example DAGs (#13665) |
| - Support tables in DAG docs (#13533) |
| - Add ``python3-openid`` dependency (#13714) |
| - Add ``__repr__`` for Executors (#13753) |
| - Add description to hint if ``conn_type`` is missing (#13778) |
| - Upgrade Azure blob to v12 (#12188) |
| - Add extra field to ``get_connnection`` REST endpoint (#13885) |
| - Make Smart Sensors DB Migration idempotent (#13892) |
| - Improve the error when DAG does not exist when running dag pause command (#13900) |
| - Update ``airflow_local_settings.py`` to fix an error message (#13927) |
| - Only allow passing JSON Serializable conf to ``TriggerDagRunOperator`` (#13964) |
| - Bugfix: Allow getting details of a DAG with null ``start_date`` (REST API) (#13959) |
| - Add params to the DAG details endpoint (#13790) |
| - Make the role assigned to anonymous users customizable (#14042) |
| - Retry critical methods in Scheduler loop in case of ``OperationalError`` (#14032) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - Add Missing Statsd Metrics in Docs (#13708) |
| - Add Missing Email configs in Configuration doc (#13709) |
| - Add quick start for Airflow on Docker (#13660) |
| - Describe which Python versions are supported (#13259) |
| - Add note block to 2.x migration docs (#13094) |
| - Add documentation about webserver_config.py (#13155) |
| - Add missing version information to recently added configs (#13161) |
| - API: Use generic information in UpdateMask component (#13146) |
| - Add Airflow 2.0.0 to requirements table (#13140) |
| - Avoid confusion in doc for CeleryKubernetesExecutor (#13116) |
| - Update docs link in REST API spec (#13107) |
| - Add link to PyPI Repository to provider docs (#13064) |
| - Fix link to Airflow master branch documentation (#13179) |
| - Minor enhancements to Sensors docs (#13381) |
| - Use 2.0.0 in Airflow docs & Breeze (#13379) |
| - Improves documentation regarding providers and custom connections (#13375)(#13410) |
| - Fix malformed table in production-deployment.rst (#13395) |
| - Update celery.rst to fix broken links (#13400) |
| - Remove reference to scheduler run_duration param in docs (#13346) |
| - Set minimum SQLite version supported (#13412) |
| - Fix installation doc (#13462) |
| - Add docs about mocking variables and connections (#13502) |
| - Add docs about Flask CLI (#13500) |
| - Fix Upgrading to 2 guide to use ``rbac`` UI (#13569) |
| - Make docs clear that Auth can not be disabled for Stable API (#13568) |
| - Remove archived links from docs & add link for AIPs (#13580) |
| - Minor fixes in upgrading-to-2.rst (#13583) |
| - Fix Link in Upgrading to 2.0 guide (#13584) |
| - Fix heading for Mocking section in best-practices.rst (#13658) |
| - Add docs on how to use custom operators within plugins folder (#13186) |
| - Update docs to register Operator Extra Links (#13683) |
| - Improvements for database setup docs (#13696) |
| - Replace module path to Class with just Class Name (#13719) |
| - Update DAG Serialization docs (#13722) |
| - Fix link to Apache Airflow docs in webserver (#13250) |
| - Clarifies differences between extras and provider packages (#13810) |
| - Add information about all access methods to the environment (#13940) |
| - Docs: Fix FAQ on scheduler latency (#13969) |
| - Updated taskflow api doc to show dependency with sensor (#13968) |
| - Add deprecated config options to docs (#13883) |
| - Added a FAQ section to the Upgrading to 2 doc (#13979) |
| |
| Airflow 2.0.0, 2020-12-18 |
| ---------------------------- |
| |
| The full changelog is about 3,000 lines long (already excluding everything backported to 1.10) |
| so please check `Airflow 2.0.0 Highligths Blog Post <https://airflow.apache.org/blog/airflow-two-point-oh-is-here/>`_ |
| instead. |
| |
| Airflow 1.10.15, 2021-03-17 |
| ---------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| - Fix ``airflow db upgrade`` to upgrade db as intended (#13267) |
| - Moved boto3 limitation to snowflake (#13286) |
| - ``KubernetesExecutor`` should accept images from ``executor_config`` (#13074) |
| - Scheduler should acknowledge active runs properly (#13803) |
| - Include ``airflow/contrib/executors`` in the dist package |
| - Pin Click version for Python 2.7 users |
| - Ensure all statsd timers use millisecond values. (#10633) |
| - [``kubernetes_generate_dag_yaml``] - Fix dag yaml generate function (#13816) |
| - Fix ``airflow tasks clear` cli command with ``--yes`` (#14188) |
| - Fix permission error on non-POSIX filesystem (#13121) (#14383) |
| - Fixed deprecation message for "variables" command (#14457) |
| - BugFix: fix the ``delete_dag`` function of json_client (#14441) |
| - Fix merging of secrets and configmaps for ``KubernetesExecutor`` (#14090) |
| - Fix webserver exiting when gunicorn master crashes (#13470) |
| - Bump ``ini`` from 1.3.5 to 1.3.8 in ``airflow/www_rbac`` |
| - Bump ``datatables.net`` from 1.10.21 to 1.10.23 in ``airflow/www_rbac`` |
| - Webserver: Sanitize string passed to origin param (#14738) |
| - Make ``rbac_app``'s ``db.session`` use the same timezone with ``@provide_session`` (#14025) |
| |
| Improvements |
| """""""""""" |
| |
| - Adds airflow as viable docker command in official image (#12878) |
| - ``StreamLogWriter``: Provide (no-op) close method (#10885) |
| - Add 'airflow variables list' command for 1.10.x transition version (#14462) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - Update URL for Airflow docs (#13561) |
| - Clarifies version args for installing 1.10 in Docker (#12875) |
| |
| Airflow 1.10.14, 2020-12-10 |
| ---------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| - BugFix: Tasks with ``depends_on_past`` or ``task_concurrency`` are stuck (#12663) |
| - Fix issue with empty Resources in executor_config (#12633) |
| - Fix: Deprecated config ``force_log_out_after`` was not used (#12661) |
| - Fix empty asctime field in JSON formatted logs (#10515) |
| - [AIRFLOW-2809] Fix security issue regarding Flask SECRET_KEY (#3651) |
| - [AIRFLOW-2884] Fix Flask SECRET_KEY security issue in www_rbac (#3729) |
| - [AIRFLOW-2886] Generate random Flask SECRET_KEY in default config (#3738) |
| - Add missing comma in setup.py (#12790) |
| - Bugfix: Unable to import Airflow plugins on Python 3.8 (#12859) |
| - Fix setup.py missing comma in ``setup_requires`` (#12880) |
| - Don't emit first_task_scheduling_delay metric for only-once dags (#12835) |
| |
| Improvements |
| """""""""""" |
| |
| - Update setup.py to get non-conflicting set of dependencies (#12636) |
| - Rename ``[scheduler] max_threads`` to ``[scheduler] parsing_processes`` (#12605) |
| - Add metric for scheduling delay between first run task & expected start time (#9544) |
| - Add new-style 2.0 command names for Airflow 1.10.x (#12725) |
| - Add Kubernetes cleanup-pods CLI command for Helm Chart (#11802) |
| - Don't let webserver run with dangerous config (#12747) |
| - Replace pkg_resources with ``importlib.metadata`` to avoid VersionConflict errors (#12694) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - Clarified information about supported Databases |
| |
| Airflow 1.10.13, 2020-11-25 |
| ---------------------------- |
| |
| New Features |
| """""""""""" |
| |
| - Add "already checked" to failed pods in K8sPodOperator (#11368) |
| - Pass SQLAlchemy engine options to FAB based UI (#11395) |
| - [AIRFLOW-4438] Add Gzip compression to S3_hook (#8571) |
| - Add permission "extra_links" for Viewer role and above (#10719) |
| - Add generate_yaml command to easily test KubernetesExecutor before deploying pods (#10677) |
| - Add Secrets backend for Microsoft Azure Key Vault (#10898) |
| |
| Bug Fixes |
| """"""""" |
| |
| - SkipMixin: Handle empty branches (#11120) |
| - [AIRFLOW-5274] dag loading duration metric name too long (#5890) |
| - Handle no Dagrun in DagrunIdDep (#8389) (#11343) |
| - Fix Kubernetes Executor logs for long dag names (#10942) |
| - Add on_kill support for the KubernetesPodOperator (#10666) |
| - KubernetesPodOperator template fix (#10963) |
| - Fix displaying of add serialized_dag table migration |
| - Fix Start Date tooltip on DAGs page (#10637) |
| - URL encode execution date in the Last Run link (#10595) |
| - Fixes issue with affinity backcompat in Airflow 1.10 |
| - Fix KubernetesExecutor import in views.py |
| - Fix issues with Gantt View (#12419) |
| - Fix Entrypoint and _CMD config variables (#12411) |
| - Fix operator field update for SerializedBaseOperator (#10924) |
| - Limited cryptography to < 3.2 for Python 2.7 |
| - Install cattr on Python 3.7 - Fix docs build on RTD (#12045) |
| - Limit version of marshmallow-sqlalchemy |
| - Pin `kubernetes` to a max version of 11.0.0 (#11974) |
| - Use snakebite-py3 for HDFS dependency for Python3 (#12340) |
| - Removes snakebite kerberos dependency (#10865) |
| - Fix failing dependencies for FAB and Celery (#10828) |
| - Fix pod_mutation_hook for 1.10.13 (#10850) |
| - Fix formatting of Host information |
| - Fix Logout Google Auth issue in Non-RBAC UI (#11890) |
| - Add missing imports to app.py (#10650) |
| - Show Generic Error for Charts & Query View in old UI (#12495) |
| - TimeSensor should respect the default_timezone config (#9699) |
| - TimeSensor should respect DAG timezone (#9882) |
| - Unify user session lifetime configuration (#11970) |
| - Handle outdated webserver session timeout gracefully. (#12332) |
| |
| |
| Improvements |
| """""""""""" |
| |
| - Add XCom.deserialize_value to Airflow 1.10.13 (#12328) |
| - Mount airflow.cfg to pod_template_file (#12311) |
| - All k8s object must comply with JSON Schema (#12003) |
| - Validate Airflow chart values.yaml & values.schema.json (#11990) |
| - Pod template file uses custom custom env variable (#11480) |
| - Bump attrs and cattrs dependencies (#11969) |
| - Bump attrs to > 20.0 (#11799) |
| - [AIRFLOW-3607] Only query DB once per DAG run for TriggerRuleDep (#4751) |
| - Rename task with duplicate task_id |
| - Manage Flask AppBuilder Tables using Alembic Migrations (#12352) |
| - ``airflow test`` only works for tasks in 1.10, not whole dags (#11191) |
| - Improve warning messaging for duplicate task_ids in a DAG (#11126) |
| - Pins moto to 1.3.14 (#10986) |
| - DbApiHook: Support kwargs in get_pandas_df (#9730) |
| - Make grace_period_seconds option on K8sPodOperator (#10727) |
| - Fix syntax error in Dockerfile 'maintainer' Label (#10899) |
| - The entrypoints in Docker Image should be owned by Airflow (#10853) |
| - Make dockerfiles Google Shell Guide Compliant (#10734) |
| - clean-logs script for Dockerfile: trim logs before sleep (#10685) |
| - When sending tasks to celery from a sub-process, reset signal handlers (#11278) |
| - SkipMixin: Add missing session.commit() and test (#10421) |
| - Webserver: Further Sanitize values passed to origin param (#12459) |
| - Security upgrade lodash from 4.17.19 to 4.17.20 (#11095) |
| - Log instead of raise an Error for unregistered OperatorLinks (#11959) |
| - Mask Password in Log table when using the CLI (#11468) |
| - [AIRFLOW-3607] Optimize dep checking when depends on past set and concurrency limit |
| - Execute job cancel HTTPRequest in Dataproc Hook (#10361) |
| - Use rst lexer to format Airflow upgrade check output (#11259) |
| - Remove deprecation warning from contrib/kubernetes/pod.py |
| - adding body as templated field for CloudSqlImportOperator (#10510) |
| - Change log level for User's session to DEBUG (#12414) |
| |
| Deprecations |
| """""""""""" |
| |
| - Deprecate importing Hooks from plugin-created module (#12133) |
| - Deprecate adding Operators and Sensors via plugins (#12069) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - [Doc] Correct description for macro task_instance_key_str (#11062) |
| - Checks if all the libraries in setup.py are listed in installation.rst file (#12023) |
| - Revise "Project Focus" copy (#12011) |
| - Move Project focus and Principles higher in the README (#11973) |
| - Remove archived link from README.md (#11945) |
| - Update download url for Airflow Version (#11800) |
| - Add Project URLs for PyPI page (#11801) |
| - Move Backport Providers docs to our docsite (#11136) |
| - Refactor rebase copy (#11030) |
| - Add missing images for kubernetes executor docs (#11083) |
| - Fix indentation in executor_config example (#10467) |
| - Enhanced the Kubernetes Executor doc (#10433) |
| - Refactor content to a markdown table (#10863) |
| - Rename "Beyond the Horizon" section and refactor content (#10802) |
| - Refactor official source section to use bullets (#10801) |
| - Add section for official source code (#10678) |
| - Add redbubble link to Airflow merchandise (#10359) |
| - README Doc: Link to Airflow directory in ASF Directory (#11137) |
| - Fix the default value for VaultBackend's config_path (#12518) |
| |
| Airflow 1.10.12, 2020-08-25 |
| ---------------------------- |
| |
| New Features |
| """""""""""" |
| |
| - Add DateTimeSensor (#9697) |
| - Add AirflowClusterPolicyViolation support to Airflow local settings (#10282) |
| - Get Airflow configs with sensitive data from Secret Backends (#9645) |
| - [AIRFLOW-4734] Upsert functionality for PostgresHook.insert_rows() (#8625) |
| - Allow defining custom XCom class (#8560) |
| |
| Bug Fixes |
| """"""""" |
| |
| - Add pre 1.10.11 Kubernetes Paths back with Deprecation Warning (#10067) |
| - Fixes PodMutationHook for backwards compatibility (#9903) |
| - Fix bug in executor_config when defining resources (#9935) |
| - Respect DAG Serialization setting when running sync_perm (#10321) |
| - Show correct duration on graph view for running task (#8311) (#8675) |
| - Fix regression in SQLThresholdCheckOperator (#9312) |
| - [AIRFLOW-6931] Fixed migrations to find all dependencies for MSSQL (#9891) |
| - Avoid sharing session with RenderedTaskInstanceFields write and delete (#9993) |
| - Fix clear future recursive when ExternalTaskMarker is used (#9515) |
| - Handle IntegrityError while creating TIs (#10136) |
| - Fix airflow-webserver startup errors when using Kerberos Auth (#10047) |
| - Fixes treatment of open slots in scheduler (#9316) (#9505) |
| - Fix KubernetesPodOperator reattachment (#10230) |
| - Fix more PodMutationHook issues for backwards compatibility (#10084) |
| - [AIRFLOW-5391] Do not re-run skipped tasks when they are cleared (#7276) |
| - Fix task_instance_mutation_hook (#9910) |
| - Fixes failing formatting of DAG file containing {} in docstring (#9779) |
| - Fix is_terminal_support_colors function (#9734) |
| - Fix PythonVirtualenvOperator when using ``provide_context=True`` (#8256) |
| - Fix issue with mounting volumes from secrets (#10366) |
| - BugFix: K8s Executor Multinamespace mode is evaluated to true by default (#10410) |
| - Make KubernetesExecutor recognize kubernetes_labels (#10412) |
| - Fix broken Kubernetes PodRuntimeInfoEnv (#10478) |
| |
| Improvements |
| """""""""""" |
| |
| - Use Hash of Serialized DAG to determine DAG is changed or not (#10227) |
| - Update Serialized DAGs in Webserver when DAGs are Updated (#9851) |
| - Do not Update Serialized DAGs in DB if DAG did not change (#9850) |
| - Add __repr__ to SerializedDagModel (#9862) |
| - Update JS packages to latest versions (#9811) (#9921) |
| - UI Graph View: Focus upstream / downstream task dependencies on mouseover (#9303) |
| - Allow ``image`` in ``KubernetesPodOperator`` to be templated (#10068) |
| - [AIRFLOW-6843] Add delete_option_kwargs to delete_namespaced_pod (#7523) |
| - Improve process terminating in scheduler_job (#8064) |
| - Replace deprecated base classes used in bigquery_check_operator (#10272) |
| - [AIRFLOW-5897] Allow setting -1 as pool slots value in webserver (#6550) |
| - Limit all google-cloud api to <2.0.0 (#10317) |
| - [AIRFLOW-6706] Lazy load operator extra links (#7327) (#10318) |
| - Add Snowflake support to SQL operator and sensor (#9843) |
| - Makes multi-namespace mode optional (#9570) |
| - Pin pyarrow < 1.0 |
| - Pin pymongo version to <3.11.0 |
| - Pin google-cloud-container to <2 (#9901) |
| - Dockerfile: Remove package.json and yarn.lock from the prod image (#9814) |
| - Dockerfile: The group of embedded DAGs should be root to be OpenShift compatible (#9794) |
| - Update upper limit of flask-swagger, gunicorn & jinja2 (#9684) |
| - Webserver: Sanitize values passed to origin param (#10334) |
| - Sort connection type list in add/edit page alphabetically (#8692) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - Add new committers: Ry Walker & Leah Cole to project.rst (#9892) |
| - Add Qingping Hou to committers list (#9725) |
| - Updated link to official documentation (#9629) |
| - Create a short-link for Airflow Slack Invites (#10034) |
| - Set language on code-block on docs/howto/email-config.rst (#10238) |
| - Remove duplicate line from 1.10.10 CHANGELOG (#10289) |
| - Improve heading on Email Configuration page (#10175) |
| - Fix link for the Jinja Project in docs/tutorial.rst (#10245) |
| - Create separate section for Cron Presets (#10247) |
| - Add Syntax Highlights to code-blocks in docs/best-practices.rst (#10258) |
| - Fix docstrings in BigQueryGetDataOperator (#10042) |
| - Fix typo in Task Lifecycle section (#9867) |
| - Make Secret Backend docs clearer about Variable & Connection View (#8913) |
| |
| Airflow 1.10.11, 2020-07-10 |
| ----------------------------- |
| |
| New Features |
| """""""""""" |
| |
| - Add task instance mutation hook (#8852) |
| - Allow changing Task States Colors (#9520) |
| - Add support for AWS Secrets Manager as Secrets Backend (#8186) |
| - Add Airflow info command to the CLI (#8704) |
| - Add Local Filesystem Secret Backend (#8596) |
| - Add Airflow config CLI command (#8694) |
| - Add Support for Python 3.8 (#8836)(#8823) |
| - Allow K8S worker pod to be configured from JSON/YAML file (#6230) |
| - Add quarterly to crontab presets (#6873) |
| - Add support for ephemeral storage on KubernetesPodOperator (#6337) |
| - Add AirflowFailException to fail without any retry (#7133) |
| - Add SQL Branch Operator (#8942) |
| |
| Bug Fixes |
| """"""""" |
| |
| - Use NULL as dag.description default value (#7593) |
| - BugFix: DAG trigger via UI error in RBAC UI (#8411) |
| - Fix logging issue when running tasks (#9363) |
| - Fix JSON encoding error in DockerOperator (#8287) |
| - Fix alembic crash due to typing import (#6547) |
| - Correctly restore upstream_task_ids when deserializing Operators (#8775) |
| - Correctly store non-default Nones in serialized tasks/dags (#8772) |
| - Correctly deserialize dagrun_timeout field on DAGs (#8735) |
| - Fix tree view if config contains " (#9250) |
| - Fix Dag Run UI execution date with timezone cannot be saved issue (#8902) |
| - Fix Migration for MSSQL (#8385) |
| - RBAC ui: Fix missing Y-axis labels with units in plots (#8252) |
| - RBAC ui: Fix missing task runs being rendered as circles instead (#8253) |
| - Fix: DagRuns page renders the state column with artifacts in old UI (#9612) |
| - Fix task and dag stats on home page (#8865) |
| - Fix the trigger_dag api in the case of nested subdags (#8081) |
| - UX Fix: Prevent undesired text selection with DAG title selection in Chrome (#8912) |
| - Fix connection add/edit for spark (#8685) |
| - Fix retries causing constraint violation on MySQL with DAG Serialization (#9336) |
| - [AIRFLOW-4472] Use json.dumps/loads for templating lineage data (#5253) |
| - Restrict google-cloud-texttospeech to <v2 (#9137) |
| - Fix pickling failure when spawning processes (#8671) |
| - Pin Version of azure-cosmos to <4 (#8956) |
| - Azure storage 0.37.0 is not installable any more (#8833) |
| - Fix modal_backdrop z-index in the UI (#7313) |
| - Fix Extra Links in Gantt View (#8308) |
| - Bug fix for EmrAddStepOperator init with cluster_name error (#9235) |
| - Fix KubernetesPodOperator pod name length validation (#8829) |
| - Fix non updating DAG code by checking against last modification time (#8266) |
| - BugFix: Unpausing a DAG with catchup=False creates an extra DAG run (#8776) |
| |
| |
| Improvements |
| """""""""""" |
| |
| - Improve add_dag_code_table migration (#8176) |
| - Persistent display/filtering of DAG status (#8106) |
| - Set unique logger names (#7330) |
| - Update the version of cattrs from 0.9 to 1.0 to support Python 3.8 (#7100) |
| - Reduce response payload size of /dag_stats and /task_stats (#8655) |
| - Add authenticator parameter to snowflake_hook (#8642) |
| - Show "Task Reschedule" table in Airflow Webserver (#9521) |
| - Change worker_refresh_interval fallback to default of 30 (#9588) |
| - Use pformat instead of str to render arguments in WebUI (#9587) |
| - Simplify DagFileProcessorManager (#7521) |
| - Reload gunicorn when plugins has been changed (#8997) |
| - Fix the default value for store_dag_code (#9554) |
| - Add support for fetching logs from running pods (#8626) |
| - Persist start/end date and duration for DummyOperator Task Instance (#8663) |
| - Ensure "started"/"ended" in tooltips are not shown if job not started (#8667) |
| - Add context to execution_date_fn in ExternalTaskSensor (#8702) |
| - Avoid color info in response of ``/dag_stats`` & ``/task_stats`` (#8742) |
| - Make loading plugins from entrypoint fault-tolerant (#8732) |
| - Refactor Kubernetes worker config (#7114) |
| - Add default ``conf`` parameter to Spark JDBC Hook (#8787) |
| - Allow passing backend_kwargs to AWS SSM client (#8802) |
| - Filter dags by clicking on tag (#8897) |
| - Support k8s auth method in Vault Secrets provider (#8640) |
| - Monitor pods by labels instead of names (#6377) |
| - Optimize count query on /home (#8729) |
| - Fix JSON string escape in tree view (#8551) |
| - Add TaskInstance state to TI Tooltip to be colour-blind friendlier (#8910) |
| - Add a tip to trigger DAG screen (#9049) |
| - Use Markup for htmlcontent for landing_times (#9242) |
| - Pinning max pandas version to 2.0 (lesser than) to allow pandas 1.0 (#7954) |
| - Update example webserver_config.py to show correct CSRF config (#8944) |
| - Fix displaying Executor Class Name in "Base Job" table (#8679) |
| - Use existing DagBag for 'dag_details' & 'trigger' Endpoints (#8501) |
| - Flush pending Sentry exceptions before exiting (#7232) |
| - Display DAG run conf in the list view (#6794) |
| - Fix performance degradation when updating dagrun state (#8435) |
| - Don't use the ``|safe`` filter in code, it's risky (#9180) |
| - Validate only task commands are run by executors (#9178) |
| - Show Deprecation warning on duplicate Task ids (#8728) |
| - Move DAG._schedule_interval logic out of ``DAG.__init__`` (#8225) |
| - Make retrieving Paused Dag ids a separate method (#7587) |
| - Bulk fetch paused_dag_ids (#7476) |
| - Add a configurable DAGs volume mount path for Kubernetes (#8147) |
| - Add schedulername option for KubernetesPodOperator (#6088) |
| - Support running git sync container as root (#6312) |
| - Add extra options for Slack Webhook operator and Slack hook (#9409) |
| - Monkey patch greenlet Celery pools (#8559) |
| - Decrypt secrets from SystemsManagerParameterStoreBackend (#9214) |
| - Prevent clickable sorting on non sortable columns in TI view (#8681) |
| - Make hive macros py3 compatible (#8598) |
| - Fix SVG tooltip positioning with custom scripting (#8269) |
| - Avoid unnecessary sleep to maintain local task job heart rate (#6553) |
| - Include some missing RBAC roles on User and Viewer roles (#9133) |
| - Show Dag's Markdown docs on Tree View (#9448) |
| - Improved compatibility with Python 3.5+ - Convert signal.SIGTERM to int (#9207) |
| - Add 'main' param to template_fields in DataprocSubmitPySparkJobOperator (#9154) |
| - Make it possible to silence warnings from Airflow (#9208) |
| - Remove redundant count query in BaseOperator.clear() (#9362) |
| - Fix DB migration message (#8988) |
| - Fix awkward log info in dbapi_hook (#8482) |
| - Fix Celery default to no longer allow pickle (#7205) |
| - Further validation that only task commands are run by executors (#9240) |
| - Remove vendored nvd3 and slugify libraries (#9136) |
| - Enable configurable git sync depth (#9094) |
| - Reduce the required resources for the Kubernetes's sidecar (#6062) |
| - Refactor K8S codebase with k8s API models (#5481) |
| - Move k8s executor out of contrib to closer match master (#8904) |
| - Allow filtering using "event" and "owner" in "Log" view (#4881) |
| - Add Yandex.Cloud custom connection to 1.10 (#8791) |
| - Add table-hover css class to DAGs table (#5033) |
| - Show un/pause errors in dags view. (#7669) |
| - Restructure database queries on /home (#4872) |
| - Add Cross Site Scripting defense (#6913) |
| - Make Gantt tooltip the same as Tree and Graph view (#8220) |
| - Add config to only delete worker pod on task failure (#7507)(#8312) |
| - Remove duplicate error message on chart connection failure (#8476) |
| - Remove default value spark_binary (#8508) |
| - Expose Airflow Webserver Port in Production Docker Image (#8228) |
| - Commit after each alembic migration (#4797) |
| - KubernetesPodOperator fixes and test (#6524) |
| - Docker Image: Add ADDITIONAL_AIRFLOW_EXTRAS (#9032) |
| - Docker Image: Add ADDITIONAL_PYTHON_DEPS (#9031) |
| - Remove httplib2 from Google requirements (#9194) |
| - Merging multiple SQL operators (#9124) |
| - Adds hive as extra in pyhive dependency (#9075) |
| - Change default auth for experimental backend to deny_all (#9611) |
| - Restrict changing XCom values from the Webserver (#9614) |
| - Add __repr__ for DagTag so tags display properly in /dagmodel/show (#8719) |
| - Functionality to shuffle HMS connections used by HiveMetastoreHook facilitating load balancing (#9280) |
| - Expose SQLAlchemy's connect_args and make it configurable (#6478) |
| |
| Doc only changes |
| """""""""""""""" |
| |
| - Add docs on using DAGRun.conf (#9578) |
| - Enforce code-block directives in doc (#9443) |
| - Carefully parse warning messages when building documentation (#8693) |
| - Make KubernetesPodOperator clear in docs (#8444) |
| - Improve language in Pod Mutation Hook docs (#8445) |
| - Fix formatting of Pool docs in concepts.rst (#8443) |
| - Make doc clearer about Airflow Variables using Environment Variables (#8427) |
| - Fix pools doc for LocalExecutor (#7643) |
| - Add Local and Sequential Executors to Doc (#8084) |
| - Add documentation for CLI command Airflow dags test (#8251) |
| - Fix typo in DAG Serialization documentation (#8317) |
| - Add scheduler in production section (#7351) |
| - Add a structural dag validation example (#6727) |
| - Adding Task re-run documentation (#6295) |
| - Fix outdated doc on settings.policy (#7532) |
| - Add docs about reload_on_plugin_change option (#9575) |
| - Add copy button to Code Blocks in Airflow Docs (#9450) |
| - Update commands in docs for v1.10+ (#9585) |
| - Add more info on dry-run CLI option (#9582) |
| - Document default timeout value for SSHOperator (#8744) |
| - Fix docs on creating CustomOperator (#8678) |
| - Enhanced documentation around Cluster Policy (#8661) |
| - Use sphinx syntax in concepts.rst (#7729) |
| - Update README to remove Python 3.8 limitation for Master (#9451) |
| - Add note about using dag_run.conf in BashOperator (#9143) |
| - Improve tutorial - Include all imports statements (#8670) |
| - Added more precise Python requirements to README.md (#8455) |
| - Fix Airflow Stable version in README.md (#9360) |
| - Update AWS connection example to show how to set from env var (#9191) |
| - Fix list formatting of plugins doc. (#8873) |
| - Add 'Version Added' on Secrets Backend docs (#8264) |
| - Simplify language re roll-your-own secrets backend (#8257) |
| - Add installation description for repeatable PyPi installation (#8513) |
| - Add note extra links only render on when using RBAC webserver (#8788) |
| - Remove unused Airflow import from docs (#9274) |
| - Add PR/issue note in Contribution Workflow Example (#9177) |
| - Don't use the term "whitelist" - language matters (#9174) |
| - Add docs to change Colors on the Webserver (#9607) |
| - Change 'initiate' to 'initialize' in installation.rst (#9619) |
| - Replace old Variables View Screenshot with new (#9620) |
| - Replace old SubDag zoom screenshot with new (#9621) |
| - Update docs about the change to default auth for experimental API (#9617) |
| |
| |
| Airflow 1.10.10, 2020-04-09 |
| --------------------------- |
| |
| New Features |
| """""""""""" |
| - [AIRFLOW-7048] Allow user to chose timezone to use in UI (#8046) |
| - Add Production Docker image support (#7832) |
| - Get Airflow Variables from Environment Variables (#7923) |
| - Get Airflow Variables from Hashicorp Vault (#7944) |
| - Get Airflow Variables from AWS Systems Manager Parameter Store (#7945) |
| - Get Airflow Variables from GCP Secrets Manager (#7946) |
| - [AIRFLOW-5705] Add secrets backend and support for AWS SSM / Get Airflow Connections from AWS Parameter Store(#6376) |
| - [AIRFLOW-7104] Add Secret backend for GCP Secrets Manager / Get Airflow Connections from GCP Secrets Manager (#7795) |
| - [AIRFLOW-7076] Add support for HashiCorp Vault as Secrets Backend / Get Airflow Connections from Hashicorp Vault (#7741) |
| - [AIRFLOW-6685] Add ThresholdCheckOperator (#7353) |
| - [AIRFLOW-7080] Add API endpoint to return a DAG's paused state (#7737) |
| |
| Bug Fixes |
| """"""""" |
| - BugFix: Show task_id in the Graph View tooltip (#7859) |
| - [AIRFLOW-6730] Use total_seconds instead of seconds (#7363) |
| - [AIRFLOW-6167] Escape column name in create table in hive (#6741) |
| - [AIRFLOW-6628] DAG auto-complete now suggests from all accessible DAGs (#7251) |
| - [AIRFLOW-7113] Fix gantt render error (#7913) |
| - [AIRFLOW-6399] Add _access control to validate deserialized DAGs (#7896) |
| - [AIRFLOW-6399] Serialization: DAG access_control field should be decorated field in DAG serialization (#7879) |
| - [AIRFLOW-4453] Make behavior of `none_failed` consistent with documentation (#7464) |
| - [AIRFLOW-4363] Fix JSON encoding error (#7628) |
| - [AIRFLOW-6683] Run REST API tests when DAGs are serialized (#7352) |
| - [AIRFLOW-6704] Copy common TaskInstance attributes from Task (#7324) |
| - [AIRFLOW-6734] Use configured base_template instead of hard-coding (#7367) |
| - [AIRFLOW-7098] Simple salesforce release 1.0.0 breaks the build (#7775) |
| - [AIRFLOW-6062] Executor would only delete workers in its own namespace (#7123) |
| - [AIRFLOW-7074] Add Permissions to view SubDAGs (#7752) |
| - [AIRFLOW-7025] Fix SparkSqlHook.run_query to handle its parameter properly (#7677) |
| - [AIRFLOW-6855] Escape project_dataset_table in SQL query in gcs to bq operator (#7475) |
| - [AIRFLOW-6949] Respect explicit conf to SparkSubmitOperator (#7575) |
| - [AIRFLOW-6588] write_stdout and json_format are boolean (#7199) |
| - [AIRFLOW-3439] Decode logs with 'utf-8' (#4474) |
| - [AIRFLOW-6878] Fix misconfigured default value for kube_client_request_args |
| - [AIRFLOW-5167] Update dependencies for GCP packages (#7116) |
| - [AIRFLOW-6821] Success callback not called when task marked as success from UI (#7447) |
| - [AIRFLOW-6740] Remove Undocumented, deprecated, dysfunctional PROXY_FIX_NUM_PROXIES (#7359) |
| - [AIRFLOW-6728] Change various DAG info methods to POST (#7364) |
| - [AIRFLOW-6997] Make sure worker pods initcontainers obtain env vars from config (#7663) |
| - [AIRFLOW-7062] Fix pydruid release breaking the build (#7720) |
| - [AIRFLOW-6040] ReadTimoutError in KubernetesExecutor should not raise exception (#7616) |
| - [AIRFLOW-6943] Fix utf-8 encoded description in DAG in Python 2 (#7567) |
| - [AIRFLOW-6892] Fix broken non-wheel releases (#7514) |
| - [AIRFLOW-6789] BugFix: Fix Default Worker concurrency (#7494) |
| - [AIRFLOW-6840] Bump up version of future (#7471) |
| - [AIRFLOW-5705] Fix bugs in AWS SSM Secrets Backend (#7745) |
| - [AIRFLOW-5705] Fix bug in Secrets Backend (#7742) |
| - Fix CloudSecretsManagerBackend invalid connections_prefix (#7861) |
| - [AIRFLOW-7045] BugFix: DebugExecutor fails to change task state. (#8073) |
| - BugFix: Datetimepicker is stuck on the UI (#8092) |
| - [AIRFLOW-5277] Gantt chart respects per-user the Timezone UI setting (#8096) |
| - Fix timezones displayed in Task Instance tooltip (#8103) |
| - BugFix: Fix writing & deleting Dag Code for Serialized DAGs (#8151) |
| - Make the default TI pool slots '1' (#8153) |
| - Fix 500 error in Security screens (#8165) |
| - Fix Viewing Dag Code for Stateless Webserver (#8159) |
| - Fix issue with sqlalchemy 1.3.16 (#8230) |
| |
| |
| Improvements |
| """""""""""" |
| - Use same tooltip for Graph and Tree views for TaskInstances (#8043) |
| - Allow DateTimePicker in Webserver to actually pick times too (#8034) |
| - [AIRFLOW-5590] Add run_id to trigger DAG run API response (#6256) |
| - [AIRFLOW-6695] Can now pass dagrun conf when triggering dags via UI (#7312) |
| - [AIRFLOW-5336] Add ability to make updating FAB perms on webserver in it optional (#5940) |
| - [AIRFLOW-1467] Allow tasks to use more than one pool slot (#7160) |
| - [AIRFLOW-6987] Avoid creating default connections (#7629) |
| - [AIRFLOW-4175] S3Hook load_file should support ACL policy parameter (#7733) |
| - [AIRFLOW-4438] Add Gzip compression to S3_hook (#7680) |
| - Allow setting Airflow Variable values to empty string (#8021) |
| - Dont schedule dummy tasks (#7880) |
| - Prevent sequential scan of task instance table (#8014) |
| - [AIRFLOW-7017] Respect default dag view in trigger dag origin (#7667) |
| - [AIRFLOW-6837] Limit description length of a Dag on HomePage (#7457) |
| - [AIRFLOW-6989] Display Rendered template_fields without accessing Dag files (#7633) |
| - [AIRFLOW-5944] Rendering templated_fields without accessing DAG files (#6788) |
| - [AIRFLOW-5946] DAG Serialization: Store source code in db (#7217) |
| - [AIRFLOW-7079] Remove redundant code for storing template_fields (#7750) |
| - [AIRFLOW-7024] Add the verbose parameter support to SparkSqlOperator (#7676) |
| - [AIRFLOW-6733] Extend not replace template (#7366) |
| - [AIRFLOW-7001] Further fix for the MySQL 5.7 UtcDateTime (#7655) |
| - [AIRFLOW-6014] Handle pods which are preempted & deleted by kubernetes but not restarted (#6606) |
| - [AIRFLOW-6950] Remove refresh_executor_config from ti.refresh_from_db (#7577) |
| - [AIRFLOW-7016] Sort dag tags in the UI (#7661) |
| - [AIRFLOW-6762] Fix link to "Suggest changes on this page" (#7387) |
| - [AIRFLOW-6948] Remove ASCII Airflow from version command (#7572) |
| - [AIRFLOW-6767] Correct name for default Athena workgroup (#7394) |
| - [AIRFLOW-6905] Update pin.svg with new pinwheel (#7524) |
| - [AIRFLOW-6801] Make use of ImportError.timestamp (#7425) |
| - [AIRFLOW-6830] Add Subject/MessageAttributes to SNS hook and operator (#7451) |
| - [AIRFLOW-6630] Resolve handlebars advisory (#7284) |
| - [AIRFLOW-6945] MySQL 5.7 is used in v1-10-test as an option |
| - [AIRFLOW-6871] Optimize tree view for large DAGs (#7492) |
| - [AIRFLOW-7063] Fix dag.clear() slowness caused by count (#7723) |
| - [AIRFLOW-7023] Remove duplicated package definitions in setup.py (#7675) |
| - [AIRFLOW-7001] Time zone removed from MySQL TIMSTAMP field inserts |
| - [AIRFLOW-7105] Unify Secrets Backend method interfaces (#7830) |
| - Make BaseSecretsBackend.build_path generic (#7948) |
| - Allow hvac package installation using 'hashicorp' extra (#7915) |
| - Standardize SecretBackend class names (#7846) |
| - [AIRFLOW-5705] Make AwsSsmSecretsBackend consistent with VaultBackend (#7753) |
| - [AIRFLOW-7045] Update SQL query to delete RenderedTaskInstanceFields (#8051) |
| - Handle DST better in Task Instance tool tips (#8104) |
| |
| Misc/Internal |
| """"""""""""" |
| - Fix Flaky TriggerDAG UI test (#8022) |
| - Remove unnecessary messages in CI (#7951) |
| - Fixes too high parallelism in CI (#7947) |
| - Install version is not persistent in breeze (#7914) |
| - Fixed automated check for image rebuild (#7912) |
| - Move Dockerfile to Dockerfile.ci (#7829) |
| - Generate requirements are now sorted (#8040) |
| - Change name of the common environment initialization function (#7805) |
| - Requirements now depend on Python version (#7841) |
| - Bring back reset db explicitly called at CI entry (#7798) |
| - Fixes unclean installation of Airflow 1.10 (#7796) |
| - [AIRFLOW-7029] Use separate docker image for running license check (#7678) |
| - [AIRFLOW-5842] Switch to Debian buster image as a base (#7647) |
| - [AIRFLOW-5828] Move build logic out from hooks/build (#7618) |
| - [AIRFLOW-6839] Even more mypy speed improvements (#7460) |
| - [AIRFLOW-6820] split breeze into functions (#7433) |
| - [AIRFLOW-7097] Install gcloud beta components in CI image (#7772) |
| - [AIRFLOW-7018] fixing travis's job name escaping problem (#7668) |
| - [AIRFLOW-7054] Breeze has an option now to reset db at entry (#7710) |
| - [AIRFLOW-7005] Added exec command to Breeze (#7649) |
| - [AIRFLOW-7015] Detect Dockerhub repo/user when building on Dockerhub (#7673) |
| - [AIRFLOW-6727] Fix minor bugs in Release Management scripts (#7355) |
| - [AIRFLOW-7013] Automated check if Breeze image needs to be pulled (#7656) |
| - [AIRFLOW-7010] Skip in-container checks for Dockerhub builds (#7652) |
| - [AIRFLOW-7011] Pin JPype release to allow to build 1.10 images |
| - [AIRFLOW-7006] Fix missing +e in Breeze script (#7648) |
| - [AIRFLOW-6979] Fix breeze test-target specific test param issue (#7614) |
| - [AIRFLOW-6932] Add restart-environment command to Breeze |
| - [AIRFLOW-6919] Make Breeze DAG-test friendly (#7539) |
| - [AIRFLOW-6838] Introduce real subcommands for Breeze (#7515) |
| - [AIRFLOW-6763] Make systems tests ready for backport tests (#7389) |
| - [AIRFLOW-6866] Fix wrong export for Mac on Breeze (#7485) |
| - [AIRFLOW-6842] Skip fixing ownership on Mac (#7469) |
| - [AIRFLOW-6841] Fixed unbounded variable on Mac (#7465) |
| - [AIRFLOW-7067] Pinned version of Apache Airflow (#7730) |
| - [AIRFLOW-7058] Add support for different DB versions (#7717) |
| - [AIRFLOW-7002] Get rid of yaml "parser" in bash (#7646) |
| - [AIRFLOW-6972] Shorter frequently used commands in Breeze (#7608) |
| |
| Doc only changes |
| """""""""""""""" |
| - Fix typo for store_serialized_dags config (#7952) |
| - Fix broken link in README.md (#7893) |
| - Separate supported Postgres versions with comma (#7892) |
| - Fix grammar in setup.py (#7877) |
| - Add Jiajie Zhong to committers list (#8047) |
| - Update Security doc for 1.10.* for auth backends (#8072) |
| - Fix Example in config_templates for Secrets Backend (#8074) |
| - Add backticks in IMAGES.rst command description (#8075) |
| - Change version_added for store_dag_code config (#8076) |
| - [AIRFLOW-XXXX] Remove duplicate docs |
| - [AIRFLOW-XXXX] Remove the defunct limitation of Dag Serialization (#7716) |
| - [AIRFLOW-XXXX] Add prerequisite tasks for all GCP operators guide (#6049) |
| - [AIRFLOW-XXXX] Simplify AWS/Azure/Databricks operators listing (#6047) |
| - [AIRFLOW-XXXX] Add external reference to all GCP operator guide (#6048) |
| - [AIRFLOW-XXXX] Simplify GCP operators listing |
| - [AIRFLOW-XXXX] Simplify Qubole operators listing |
| - [AIRFLOW-XXXX] Add autogenerated TOC (#6038) |
| - [AIRFLOW-XXXX] Create "Using the CLI" page (#5823) |
| - [AIRFLOW-XXXX] Group references in one section (#5776) |
| - [AIRFLOW-XXXX] Fix analytics doc (#5885) |
| - [AIRFLOW-XXXX] Add S3 Logging section (#6039) |
| - [AIRFLOW-XXXX] Move Azure Logging section above operators (#6040) |
| - [AIRFLOW-XXXX] Update temp link to a fixed link (#7715) |
| - [AIRFLOW-XXXX] Add Updating.md section for 1.10.9 (#7385) |
| - [AIRFLOW-XXXX] Remove duplication in BaseOperator docstring (#7321) |
| - [AIRFLOW-XXXX] Update tests info in CONTRIBUTING.rst (#7466) |
| - [AIRFLOW-XXXX] Small BREEZE.rst update (#7487) |
| - [AIRFLOW-XXXX] Add instructions for logging to localstack S3 (#7461) |
| - [AIRFLOW-XXXX] Remove travis config warnings (#7467) |
| - [AIRFLOW-XXXX] Add communication chapter to contributing (#7204) |
| - [AIRFLOW-XXXX] Add known issue - example_dags/__init__.py (#7444) |
| - [AIRFLOW-XXXX] Fix breeze build-docs (#7445) |
| - [AIRFLOW-XXXX] Less verbose docker builds |
| - [AIRFLOW-XXXX] Speed up mypy runs (#7421) |
| - [AIRFLOW-XXXX] Fix location of kubernetes tests (#7373) |
| - [AIRFLOW-XXXX] Remove quotes from domains in Google Oauth (#4226) |
| - [AIRFLOW-XXXX] Add explicit info about JIRAs for code-related PRs (#7318) |
| - [AIRFLOW-XXXX] Fix typo in the word committer (#7392) |
| - [AIRFLOW-XXXX] Remove duplicated paragraph in docs (#7662) |
| - Fix reference to KubernetesPodOperator (#8100) |
| |
| |
| Airflow 1.10.9, 2020-02-07 |
| -------------------------- |
| |
| Bug Fixes |
| """"""""" |
| |
| - [AIRFLOW-6751] Pin Werkzeug (dependency of a number of our dependencies) to < 1.0.0 (#7377) |
| |
| Airflow 1.10.8, 2020-02-07 |
| -------------------------- |
| |
| New Features |
| """""""""""" |
| - [AIRFLOW-4026] Add filter by DAG tags (#6489) |
| - [AIRFLOW-6613] Center dag on graph view load (#7238) |
| - [AIRFLOW-5843] Add conf option to Add DAG Run view (#7281) |
| - [AIRFLOW-4495] Allow externally triggered dags to run for future exec dates (#7038) |
| |
| Improvements |
| """""""""""" |
| - [AIRFLOW-6438] Filter DAGs returned by blocked (#7019) |
| - [AIRFLOW-6666] Resolve js-yaml advisory (#7283) |
| - [AIRFLOW-6632] Bump dagre-d3 to resolve lodash CVE advisory (#7280) |
| - [AIRFLOW-6667] Resolve serialize-javascript advisory (#7282) |
| - [AIRFLOW-6451] self._print_stat() in dag_processing.py should be skipable (#7134) |
| - [AIRFLOW-6495] Load DAG only once when running a task using StandardTaskRunner (#7090) |
| - [AIRFLOW-6319] Add support for AWS Athena workgroups (#6871) |
| - [AIRFLOW-6677] Remove deprecation warning from SQLAlchmey (#7289) |
| - [AIRFLOW-6428] Fix import path for airflow.utils.dates.days_ago in Example DAGs (#7007) |
| - [AIRFLOW-6595] Use TaskNotFound exception instead of AirflowException (#7210) |
| - [AIRFLOW-6620] Mock celery in worker cli test (#7243) |
| - [AIRFLOW-6608] Change logging level for Bash & PyOperator Env exports |
| - [AIRFLOW-2279] Clear tasks across DAGs if marked by ExternalTaskMarker (#6633) |
| - [AIRFLOW-6359] Make Spark status_poll_interval explicit (#6978) |
| - [AIRFLOW-6359] spark_submit_hook.py status polling interval config (#6909) |
| - [AIRFLOW-6316] Use exampleinclude directives in tutorial.rst (#6868) |
| - [AIRFLOW-6519] Make TI logs constants in Webserver configurable (#7113) |
| - [AIRFLOW-6327] http_hook: Accept json= parameter for payload (#6886) |
| - [AIRFLOW-6261] flower_basic_auth eligible to _cmd (#6825) |
| - [AIRFLOW-6238] Filter dags returned by dag_stats |
| - [AIRFLOW-5616] Switch PrestoHook from pyhive to presto-python-client |
| - [AIRFLOW-6611] Add proxy_fix configs to default_airflow.cfg (#7236) |
| - [AIRFLOW-6557] Add test for newly added fields in BaseOperator (#7162) |
| - [AIRFLOW-6584] Pin cassandra driver (#7194) |
| - [AIRFLOW-6537] Fix backticks in RST files (#7140) |
| - [AIRFLOW-4428] Error if exec_date before default_args.start_date in trigger_dag (#6948) |
| - [AIRFLOW-6330] Show cli help when param blank or typo (#6883) |
| - [AIRFLOW-4113] Unpin boto3 (#6884) |
| - [AIRFLOW-6181] Add DebugExecutor (#6740) |
| - [AIRFLOW-6504] Allow specifying configmap for Airflow Local Setting (#7097) |
| - [AIRFLOW-6436] Cleanup for Airflow configs doc generator code (#7036) |
| - [AIRFLOW-6436] Add x_frame_enabled config in config.yml (#7024) |
| - [AIRFLOW-6436] Create & Automate docs on Airflow Configs (#7015) |
| - [AIRFLOW-6527] Make send_task_to_executor timeout configurable (#7143) |
| - [AIRFLOW-6272] Switch from npm to yarnpkg for managing front-end dependencies (#6844) |
| - [AIRFLOW-6350] Security - spark submit operator logging+exceptions should mask passwords |
| - [AIRFLOW-6358] Log details of failed task (#6908) |
| - [AIRFLOW-5149] Skip SLA checks config (#6923) |
| - [AIRFLOW-6057] Update template_fields of the PythonSensor (#6656) |
| - [AIRFLOW-4445] Mushroom cloud errors too verbose (#6952) |
| - [AIRFLOW-6394] Simplify github PR template (#6955) |
| - [AIRFLOW-5385] spark hook does not work on spark 2.3/2.4 (#6976) |
| |
| Bug Fixes |
| """"""""" |
| - [AIRFLOW-6345] Ensure arguments to ProxyFix are integers (#6901) |
| - [AIRFLOW-6576] Fix scheduler crash caused by deleted task with sla misses (#7187) |
| - [AIRFLOW-6686] Fix syntax error constructing list of process ids (#7298) |
| - [AIRFLOW-6683] REST API respects store_serialized_dag setting (#7296) |
| - [AIRFLOW-6553] Add upstream_failed in instance state filter to WebUI (#7159) |
| - [AIRFLOW-6357] Highlight nodes in Graph UI if task id contains dots (#6904) |
| - [AIRFLOW-3349] Use None instead of False as value for encoding in StreamLogWriter (#7329) |
| - [AIRFLOW-6627] Email with incorrect DAG not delivered (#7250) |
| - [AIRFLOW-6637] Fix Airflow test command in 1.10.x |
| - [AIRFLOW-6636] Avoid exceptions when printing task instance |
| - [AIRFLOW-6522] Clear task log file before starting to fix duplication in S3TaskHandler (#7120) |
| - [AIRFLOW-5501] Make default `in_cluster` value in KubernetesPodOperator respect config (#6124) |
| - [AIRFLOW-6514] Use RUNNING_DEPS to check run from UI (#6367) |
| - [AIRFLOW-6381] Remove styling based on DAG id from DAGs page (#6985) |
| - [AIRFLOW-6434] Add return statement back to DockerOperator.execute (#7013) |
| - [AIRFLOW-2516] Fix mysql deadlocks (#6988) |
| - [AIRFLOW-6528] Disable flake8 W503 line break before binary operator (#7124) |
| - [AIRFLOW-6517] Make merge_dicts function recursive (#7111) |
| - [AIRFLOW-5621] Failure callback is not triggered when marked Failed on UI (#7025) |
| - [AIRFLOW-6353] Security - ui - add click jacking defense (#6995) |
| - [AIRFLOW-6348] Security - cli.py is currently printing logs with password (#6915) |
| - [AIRFLOW-6323] Remove non-ascii letters from default config (#6878) |
| - [AIRFLOW-6506] Fix do_xcom_push defaulting to True in KubernetesPodOperator (#7122) |
| - [AIRFLOW-6516] BugFix: airflow.cfg does not exist in Volume Mounts (#7109) |
| - [AIRFLOW-6427] Fix broken example_qubole_operator dag (#7005) |
| - [AIRFLOW-6385] BugFix: SlackAPIPostOperator fails when blocks not set (#7022) |
| - [AIRFLOW-6347] BugFix: Can't get task logs when serialization is enabled (#7092) |
| - [AIRFLOW-XXXX] Fix downgrade of db migration 0e2a74e0fc9f (#6859) |
| - [AIRFLOW-6366] Fix migrations for MS SQL Server (#6920) |
| - [AIRFLOW-5406] Allow spark without kubernetes (#6921) |
| - [AIRFLOW-6229] SparkSubmitOperator polls forever if status JSON can't… (#6918) |
| - [AIRFLOW-6352] Security - ui - add login timeout (#6912) |
| - [AIRFLOW-6397] Ensure sub_process attribute exists before trying to kill it (#6958) |
| - [AIRFLOW-6400] Fix pytest not working on Windows (#6964) |
| - [AIRFLOW-6418] Remove SystemTest.skip decorator (#6991) |
| - [AIRFLOW-6425] Serialization: Add missing DAG parameters to JSON Schema (#7002) |
| |
| Misc/Internal |
| """"""""""""" |
| - [AIRFLOW-6467] Use self.dag i/o creating a new one (#7067) |
| - [AIRFLOW-6490] Improve time delta comparison in local task job tests (#7083) |
| - [AIRFLOW-5814] Implementing Presto hook tests (#6491) |
| - [AIRFLOW-5704] Improve Kind Kubernetes scripts for local testing (#6516) |
| - [AIRFLOW-XXXX] Move airflow-config-yaml pre-commit before pylint (#7108) |
| - [AIRFLOW-XXXX] Improve clarity of confirm message (#7110) |
| - [AIRFLOW-6662] install dumb init (#7300) |
| - [AIRFLOW-6705] One less chatty message at breeze initialisation (#7326) |
| - [AIRFLOW-6705] Less chatty integration/backend checks (#7325) |
| - [AIRFLOW-6662] Switch to --init docker flag for signal propagation (#7278) |
| - [AIRFLOW-6661] Fail after 50 failing tests (#7277) |
| - [AIRFLOW-6607] Get rid of old local scripts for Breeze (#7225) |
| - [AIRFLOW-6589] BAT tests run in pre-commit on bash script changes (#7203) |
| - [AIRFLOW-6592] Doc build is moved to test phase (#7208) |
| - [AIRFLOW-6641] Better diagnostics for kubernetes flaky tests (#7261) |
| - [AIRFLOW-6642] Make local task job test less flaky (#7262) |
| - [AIRFLOW-6643] Fix flakiness of kerberos tests |
| - [AIRFLOW-6638] Remove flakiness test from test_serialized_db remove |
| - [AIRFLOW-6701] Rat is downloaded from stable backup/mirrors (#7323) |
| - [AIRFLOW-6702] Dumping kind logs to file.io. (#7319) |
| - [AIRFLOW-6491] Improve handling of Breeze parameters (#7084) |
| - [AIRFLOW-6470] Avoid pipe to file when do curl (#7063) |
| - [AIRFLOW-6471] Add pytest-instafail plugin (#7064) |
| - [AIRFLOW-6462] Limit exported variables in Dockerfile/Breeze (#7057) |
| - [AIRFLOW-6465] Add bash autocomplete for Airflow in Breeze (#7060) |
| - [AIRFLOW-6464] Add cloud providers CLI tools in Breeze (#7059) |
| - [AIRFLOW-6461] Remove silent flags in Dockerfile (#7052) |
| - [AIRFLOW-6459] Increase verbosity of pytest (#7049) |
| - [AIRFLOW-6370] Skip Cassandra tests if cluster is not up (#6926) |
| - [AIRFLOW-6511] Remove BATS docker containers (#7103) |
| - [AIRFLOW-6475] Remove duplication of volume mount specs in Breeze.. (#7065) |
| - [AIRFLOW-6489] Add BATS support for Bash unit testing (#7081) |
| - [AIRFLOW-6387] print details of success/skipped task (#6956) |
| - [AIRFLOW-6568] Add Emacs related files to .gitignore (#7175) |
| - [AIRFLOW-6575] Entropy source for CI tests is changed to unblocking (#7185) |
| - [AIRFLOW-6496] Separate integrations in tests (#7091) |
| - [AIRFLOW-6634] Set PYTHONPATH in interactive Breeze |
| - [AIRFLOW-6564] Additional diagnostics information on CI check failure (#7172) |
| - [AIRFLOW-6383] Add no trailing-whitespace pre-commit hook (#6941) |
| |
| Doc only changes |
| """""""""""""""" |
| - [AIRFLOW-XXXX] Consistency fixes in new documentation (#7207) |
| - [AIRFLOW-XXXX] Improve grammar and structure in FAQ doc (#7291) |
| - [AIRFLOW-XXXX] Fix email configuration link in CONTRIBUTING.rst (#7311) |
| - [AIRFLOW-XXXX] Update docs with new BranchPythonOperator behaviour (#4682) |
| - [AIRFLOW-XXXX] Fix Typo in scripts/ci/ci_run_airflow_testing.sh (#7235) |
| - [AIRFLOW-XXXX] Screenshot showing disk space configuration for OSX (#7226) |
| - [AIRFLOW-XXXX] Add mentoring information to contributing docs (#7202) |
| - [AIRFLOW-XXXX] Add rebase info to contributing (#7201) |
| - [AIRFLOW-XXXX] Increase verbosity of static checks in CI (#7200) |
| - [AIRFLOW-XXXX] Adds branching strategy to documentation (#7193) |
| - [AIRFLOW-XXXX] Move email configuration from the concept page (#7189) |
| - [AIRFLOW-XXXX] Update task lifecycle diagram (#7161) |
| - [AIRFLOW-XXXX] Fix reference in concepts doc (#7135) |
| - [AIRFLOW-XXXX] Clear debug docs (#7104) |
| - [AIRFLOW-XXXX] Fix typos and broken links in development docs (#7086) |
| - [AIRFLOW-XXXX] Clarify wait_for_downstream and execution_date (#6999) |
| - [AIRFLOW-XXXX] Add `airflow dags show` command guide (#7014) |
| - [AIRFLOW-XXXX] Update operation chaining documentation (#7018) |
| - [AIRFLOW-XXXX] Add `.autoenv_leave.zsh` to .gitignore (#6986) |
| - [AIRFLOW-XXXX] Fix development packages installation instructions (#6942) |
| - [AIRFLOW-XXXX] Update committers list (#7212) |
| - [AIRFLOW-XXXX] Move UPDATING changes into correct versions (#7166) |
| - [AIRFLOW-XXXX] Add Documentation for check_slas flag (#6974) |
| - [AIRFLOW-XXXX] Fix gcp keyfile_dict typo (#6962) |
| - [AIRFLOW-XXXX] Add tips for writing a note in UPDATIND.md (#6960) |
| - [AIRFLOW-XXXX] Add note warning that bash>4.0 is required for docs build script (#6947) |
| - [AIRFLOW-XXXX] Add autoenv to gitignore (#6946) |
| - [AIRFLOW-XXXX] Fix GCSTaskHandler Comment Typo (#6928) |
| - [AIRFLOW-XXXX] Fix broken DAG Serialization Link (#6891) |
| - [AIRFLOW-XXXX] Add versions_added field to configs |
| |
| |
| Airflow 1.10.7, 2019-12-24 |
| -------------------------- |
| |
| New Features |
| """""""""""" |
| - [AIRFLOW-5088][AIP-24] Persisting serialized DAG in DB for webserver scalability (#5992) |
| - [AIRFLOW-6083] Adding ability to pass custom configuration to AWS Lambda client. (#6678) |
| - [AIRFLOW-5117] Automatically refresh EKS API tokens when needed (#5731) |
| - [AIRFLOW-5118] Add ability to specify optional components in DataprocClusterCreateOperator (#5821) |
| - [AIRFLOW-5681] Allow specification of a tag or hash for the git_sync init container (#6350) |
| - [AIRFLOW-6025] Add label to uniquely identify creator of Pod (#6621) |
| - [AIRFLOW-4843] Allow orchestration via Docker Swarm (SwarmOperator) (#5489) |
| - [AIRFLOW-5751] add get_uri method to Connection (#6426) |
| - [AIRFLOW-6056] Allow EmrAddStepsOperator to accept job_flow_name as alternative to job_flow_id (#6655) |
| - [AIRFLOW-2694] Declare permissions in DAG definition (#4642) |
| - [AIRFLOW-4940] Add DynamoDB to S3 operator (#5663) |
| - [AIRFLOW-4161] BigQuery to MySQL Operator (#5711) |
| - [AIRFLOW-6041] Add user agent to the Discovery API client (#6636) |
| - [AIRFLOW-6089] Reorder setup.py dependencies and add ci (#6681) |
| - [AIRFLOW-5921] Add bulk_load_custom to MySqlHook (#6575) |
| - [AIRFLOW-5854] Add support for `tty` parameter in Docker related operators (#6542) |
| - [AIRFLOW-4758] Add GcsToGDriveOperator operator (#5822) |
| |
| Improvements |
| """""""""""" |
| - [AIRFLOW-3656] Show doc link for the current installed version (#6690) |
| - [AIRFLOW-5665] Add path_exists method to SFTPHook (#6344) |
| - [AIRFLOW-5729] Make InputDataConfig optional in Sagemaker's training config (#6398) |
| - [AIRFLOW-5045] Add ability to create Google Dataproc cluster with custom image from a different project (#5752) |
| - [AIRFLOW-6132] Allow to pass in tags for the AzureContainerInstancesOperator (#6694) |
| - [AIRFLOW-5945] Make inbuilt OperatorLinks work when using Serialization (#6715) |
| - [AIRFLOW-5947] Make the JSON backend pluggable for DAG Serialization (#6630) |
| - [AIRFLOW-6239] Filter dags return by last_dagruns (to only select visible dags, not all dags) (#6804) |
| - [AIRFLOW-6095] Filter dags returned by task_stats (to only select visible dags, not all dags) (#6684) |
| - [AIRFLOW-4482] Add execution_date to "trigger DagRun" API response (#5260) |
| - [AIRFLOW-1076] Add get method for template variable accessor (#6793) |
| - [AIRFLOW-5194] Add error handler to action log (#5883) |
| - [AIRFLOW-5936] Allow explicit get_pty in SSHOperator (#6586) |
| - [AIRFLOW-5474] Add Basic auth to Druid hook (#6095) |
| - [AIRFLOW-5726] Allow custom filename in RedshiftToS3Transfer (#6396) |
| - [AIRFLOW-5834] Option to skip serve_logs process with ``airflow worker`` (#6709) |
| - [AIRFLOW-5583] Extend the 'DAG Details' page to display the start_date / end_date (#6235) |
| - [AIRFLOW-6250] Ensure on_failure_callback always has a populated context (#6812) |
| - [AIRFLOW-6222] http hook logs response body for any failure (#6779) |
| - [AIRFLOW-6260] Drive _cmd config option by env var (``AIRFLOW__CORE__SQL_ALCHEMY_CONN_CMD`` for example) (#6801) |
| - [AIRFLOW-6168] Allow proxy_fix middleware of webserver to be configurable (#6723) |
| - [AIRFLOW-5931] Use os.fork when appropriate to speed up task execution. (#6627) |
| - [AIRFLOW-4145] Allow RBAC roles permissions, ViewMenu to be over-rideable (#4960) |
| - [AIRFLOW-5928] Hive hooks load_file short circuit (#6582) |
| - [AIRFLOW-5313] Add params support for awsbatch_operator (#5900) |
| - [AIRFLOW-2227] Add delete method to Variable class (#4963) |
| - [AIRFLOW-5082] Add subject in AwsSnsHook (#5694) |
| - [AIRFLOW-5715] Make email, owner context available (#6385) |
| - [AIRFLOW-5345] Allow SqlSensor's hook to be customized by subclasses (#5946) |
| - [AIRFLOW-5417] Fix DB disconnects during webserver startup (#6023) |
| - [AIRFLOW-5730] Enable get_pandas_df on PinotDbApiHook (#6399) |
| - [AIRFLOW-3235] Add list function in AzureDataLakeHook (#4070) |
| - [AIRFLOW-5442] implementing get_pandas_df method for druid broker hook (#6057) |
| - [AIRFLOW-5883] Improve count() queries in a few places (#6532) |
| - [AIRFLOW-5811] Add metric for externally killed task count (#6466) |
| - [AIRFLOW-5758] Support the custom cursor classes for the PostgreSQL hook (#6432) |
| - [AIRFLOW-5766] Use httpbin.org in http_default (#6438) |
| - [AIRFLOW-5798] Set default ExternalTaskSensor.external_task_id (#6431) |
| - [AIRFLOW-5643] Reduce duplicated logic in S3Hook (#6313) |
| - [AIRFLOW-5562] Skip grant single DAG permissions for Admin role. (#6199) |
| - [AIRFLOW-6192] Stop creating Hook from SFTPSensor.__init__ (#6748) |
| - [AIRFLOW-5749][AIRFLOW-4162] Support the "blocks" component for the Slack operators (#6418) |
| - [AIRFLOW-5693] Support the "blocks" component for the Slack messages (#6364) |
| - [AIRFLOW-5714] Collect SLA miss emails only from tasks missed SLA (#6384) |
| - [AIRFLOW-5049] Add validation for src_fmt_configs in bigquery hook (#5671) |
| - [AIRFLOW-6177] Log DAG processors timeout event at error level, not info (#6731) |
| - [AIRFLOW-6180] Improve kerberos init in pytest conftest (#6735) |
| - [AIRFLOW-6159] Change logging level of the heartbeat message to DEBUG (#6716) |
| - [AIRFLOW-6144] Improve the log message of Airflow scheduler (#6710) |
| - [AIRFLOW-6045] Error on failed execution of compile_assets (#6640) |
| - [AIRFLOW-5144] Add confirmation on delete button click (#6745) |
| - [AIRFLOW-6099] Add host name to task runner log (#6688) |
| - [AIRFLOW-5915] Add support for the new documentation theme (#6563) |
| - [AIRFLOW-5897] Allow setting -1 as pool slots value in webserver (#6550) |
| - [AIRFLOW-5888] Use psycopg2-binary for postgres operations (#6533) |
| - [AIRFLOW-5870] Allow -1 for pool size and optimise pool query (#6520) |
| |
| Bug Fixes |
| """"""""" |
| - [AIRFLOW-XXX] Bump Jira version to fix issue with async |
| - [AIRFLOW-XXX] Add encoding to fix Cyrillic output when reading back task logs (#6631) |
| - [AIRFLOW-5304] Fix extra links in BigQueryOperator with multiple queries (#5906) |
| - [AIRFLOW-6268] Prevent (expensive) ajax calls on home page when no dags visible (#6839) |
| - [AIRFLOW-6259] Reset page to 1 with each new search for dags (#6828) |
| - [AIRFLOW-6185] SQLAlchemy Connection model schema not aligned with Alembic schema (#6754) |
| - [AIRFLOW-3632] Only replace microseconds if execution_date is None in trigger_dag REST API (#6380) |
| - [AIRFLOW-5458] Bump Flask-AppBuilder to 2.2.0 (for Python >= 3.6) (#6607) |
| - [AIRFLOW-5072] gcs_hook should download files once (#5685) |
| - [AIRFLOW-5744] Environment variables not correctly set in Spark submit operator (#6796) |
| - [AIRFLOW-3189] Remove schema from DbHook.get_uri response if None (#6833) |
| - [AIRFLOW-6195] Fixed TaskInstance attrs not correct on UI (#6758) |
| - [AIRFLOW-5889] Make polling for AWS Batch job status more resilient (#6765) |
| - [AIRFLOW-6043] Fix bug in UI when "filtering by root" to display section of dag (#6638) |
| - [AIRFLOW-6033] Fix UI Crash at "Landing Times" when task_id is changed (#6635) |
| - [AIRFLOW-3745] Fix viewer not able to view dag details (#4569) |
| - [AIRFLOW-6175] Fixes bug when tasks get stuck in "scheduled" state (#6732) |
| - [AIRFLOW-5463] Make Variable.set when replacing an atomic operation (#6807) |
| - [AIRFLOW-5582] Add get_autocommit to JdbcHook (#6232) |
| - [AIRFLOW-5867] Fix webserver unit_test_mode data type (#6517) |
| - [AIRFLOW-5819] Update AWSBatchOperator default value (#6473) |
| - [AIRFLOW-5709] Fix regression in setting custom operator resources. (#6331) |
| - [AIRFLOW-5658] Fix broken navigation links (#6374) |
| - [AIRFLOW-5727] SqoopHook: Build --connect parameter only if port/schema are defined (#6397) |
| - [AIRFLOW-5695] use RUNNING_DEPS to check run from UI (#6367) |
| - [AIRFLOW-6254] obscure conn extra in logs (#6817) |
| - [AIRFLOW-4824] Add charset handling for SqlAlchemy engine for MySqlHook (#6816) |
| - [AIRFLOW-6091] Add flushing in execute method for BigQueryCursor (#6683) |
| - [AIRFLOW-6256] Ensure Jobs table is cleared when resetting DB (#6818) |
| - [AIRFLOW-5224] Add encoding parameter to GoogleCloudStorageToBigQuery (#6297) |
| - [AIRFLOW-5179] Remove top level __init__.py (#5818) |
| - [AIRFLOW-5660] Attempt to find the task in DB from Kubernetes pod labels (#6340) |
| - [AIRFLOW-6241] Fix typo in airflow/gcp/operator/dataflow.py (#6806) |
| - [AIRFLOW-6171] Apply .airflowignore to correct subdirectories (#6784) |
| - [AIRFLOW-6018] Display task instance in table during backfilling (#6612) |
| - [AIRFLOW-6189] Reduce the maximum test duration to 8 minutes (#6744) |
| - [AIRFLOW-6141] Remove ReadyToRescheduleDep if sensor mode == poke (#6704) |
| - [AIRFLOW-6054] Add a command that starts the database consoles (#6653) |
| - [AIRFLOW-6047] Simplify the logging configuration template (#6644) |
| - [AIRFLOW-6017] Exclude PULL_REQUEST_TEMPLATE.md from RAT check (#6611) |
| - [AIRFLOW-4560] Fix Tez queue parameter name in mapred_queue (#5315) |
| - [AIRFLOW-2143] Fix TaskTries graph counts off-by-1 (#6526) |
| - [AIRFLOW-5873] KubernetesPodOperator fixes and test (#6523) |
| - [AIRFLOW-5869] BugFix: Some Deserialized tasks have no start_date (#6519) |
| - [AIRFLOW-4020] Remove DAG edit permissions from Viewer role (#4845) |
| - [AIRFLOW-6263] Fix broken WinRM integration (#6832) |
| - [AIRFLOW-5836] Pin azure-storage-blob version to <12 (#6486) |
| - [AIRFLOW-4488] Fix typo for non-RBAC UI in max_active_runs_per_dag (#6778) |
| - [AIRFLOW-5942] Pin PyMSSQL to <3.0 (#6592) |
| - [AIRFLOW-5451] SparkSubmitHook don't set default namespace (#6072) |
| - [AIRFLOW-6271] Printing log files read during load_test_config (#6842) |
| - [AIRFLOW-6308] Unpin Kombu for Python 3 |
| |
| Misc/Internal |
| """"""""""""" |
| - [AIRFLOW-6009] Switch off travis_wait for regular tests (#6600) |
| - [AIRFLOW-6226] Always reset warnings in tests |
| - [AIRFLOW-XXX] Remove cyclic imports and pylint hacks in Serialization (#6601) |
| - [AIRFLOW-XXX] Bump npm from 6.4.1 to 6.13.4 in /airflow/www (#6815) |
| - [AIRFLOW-XXX] Remove executable permission from file |
| - [AIRFLOW-XXX] Group AWS & Azure dependencies (old ``[emr]`` etc. extra still work) |
| - [AIRFLOW-5487] Fix unused warning var (#6111) |
| - [AIRFLOW-5925] Relax ``funcsigs`` and psutil version requirements (#6580) |
| - [AIRFLOW-5740] Fix Transient failure in Slack test (#6407) |
| - [AIRFLOW-6058] Running tests with pytest (#6472) |
| - [AIRFLOW-6066] Added pre-commit checks for accidental debug stmts (#6662) |
| - [AIRFLOW-6060] Improve conf_vars context manager (#6658) |
| - [AIRFLOW-6044] Standardize the Code Structure in kube_pod_operator.py (#6639) |
| - [AIRFLOW-4940] Simplify tests of DynamoDBToS3Operator (#6836) |
| - [AIRFLOW-XXX] Update airflow-jira release management script (#6772) |
| - [AIRFLOW-XXX] Add simple guidelines to unit test writing (#6846) |
| - [AIRFLOW-6309] Fix stable build on Travis |
| |
| Doc only changes |
| """""""""""""""" |
| - [AIRFLOW-6211] Doc how to use conda for local virtualenv (#6766) |
| - [AIRFLOW-5855] Fix broken reference in custom operator doc (#6508) |
| - [AIRFLOW-5875] Fix typo in example_qubole_operator.py (#6525) |
| - [AIRFLOW-5702] Fix common docstring issues (#6372) |
| - [AIRFLOW-5640] Document and test ``email`` parameters of BaseOperator (#6315) |
| - [AIRFLOW-XXX] Improve description OpenFaaS Hook (#6187) |
| - [AIRFLOW-XXX] GSoD: How to make DAGs production ready (#6515) |
| - [AIRFLOW-XXX] Use full command in examples (#5973) |
| - [AIRFLOW-XXX] Update docs to accurately describe the precedence of remote and local logs (#5607) |
| - [AIRFLOW-XXX] Fix example "extras" field in mysql connect doc (#5285) |
| - [AIRFLOW-XXX] Fix wrong inline code highlighting in docs (#5309) |
| - [AIRFLOW-XXX] Group executors in one section (#5834) |
| - [AIRFLOW-XXX] Add task lifecycle diagram to documentation (#6762) |
| - [AIRFLOW-XXX] Highlight code blocks (#6243) |
| - [AIRFLOW-XXX] Documents about task_concurrency and pool (#5262) |
| - [AIRFLOW-XXX] Fix incorrect docstring parameter (#6649) |
| - [AIRFLOW-XXX] Add link to XCom section in concepts.rst (#6791) |
| - [AIRFLOW-XXX] Update kubernetes doc with correct path (#6774) |
| - [AIRFLOW-XXX] Add information how to configure pytest runner (#6736) |
| - [AIRFLOW-XXX] More GSOD improvements (#6585) |
| - [AIRFLOW-XXX] Clarified a grammatically incorrect sentence (#6667) |
| - [AIRFLOW-XXX] Add notice for Mesos Executor deprecation in docs (#6712) |
| - [AIRFLOW-XXX] Update list of pre-commits (#6603) |
| - [AIRFLOW-XXX] Updates to Breeze documentation from GSOD (#6285) |
| - [AIRFLOW-XXX] Clarify daylight savings time behavior (#6324) |
| - [AIRFLOW-XXX] GSoD: Adding 'Create a custom operator' doc (#6348) |
| - [AIRFLOW-XXX] Add resources & links to CONTRIBUTING.rst (#6405) |
| - [AIRFLOW-XXX] Update chat channel details from gitter to slack (#4149) |
| - [AIRFLOW-XXX] Add logo info to readme (#6349) |
| - [AIRFLOW-XXX] Fixed case problem with CONTRIBUTING.rst (#6329) |
| - [AIRFLOW-XXX] Google Season of Docs updates to CONTRIBUTING doc (#6283) |
| |
| |
| Airflow 1.10.6, 2019-10-28 |
| -------------------------- |
| |
| New Features |
| """""""""""" |
| - [AIRFLOW-4908] Implement BigQuery Hooks/Operators for update_dataset, patch_dataset and get_dataset (#5546) |
| - [AIRFLOW-4741] Optionally report task errors to Sentry (#5407) |
| - [AIRFLOW-4939] Add default_task_retries config (#5570) |
| - [AIRFLOW-5508] Add config setting to limit which StatsD metrics are emitted (#6130) |
| - [AIRFLOW-4222] Add cli autocomplete for bash & zsh (#5789) |
| - [AIRFLOW-3871] Operators template fields can now render fields inside objects (#4743) |
| |
| Improvements |
| """""""""""" |
| - [AIRFLOW-5127] Gzip support for CassandraToGoogleCloudStorageOperator (#5738) |
| - [AIRFLOW-5125] Add gzip support for AdlsToGoogleCloudStorageOperator (#5737) |
| - [AIRFLOW-5124] Add gzip support for S3ToGoogleCloudStorageOperator (#5736) |
| - [AIRFLOW-5653] Log AirflowSkipException in task instance log to make it clearer why tasks might be skipped (#6330) |
| - [AIRFLOW-5343] Remove legacy SQLAlchmey pessimistic pool disconnect handling (#6034) |
| - [AIRFLOW-5561] Relax httplib2 version required for gcp extra (#6194) |
| - [AIRFLOW-5657] Update the upper bound for dill dependency (#6334) |
| - [AIRFLOW-5292] Allow ECSOperator to tag tasks (#5891) |
| - [AIRFLOW-4939] Simplify Code for Default Task Retries (#6233) |
| - [AIRFLOW-5126] Read ``aws_session_token`` in extra_config of the aws hook (#6303) |
| - [AIRFLOW-5636] Allow adding or overriding existing Operator Links (#6302) |
| - [AIRFLOW-4965] Handle quote exceptions in GCP AI operators (v1.10) (#6304) |
| - [AIRFLOW-3783] Speed up Redshift to S3 unload with HEADERs (#6309) |
| - [AIRFLOW-3388] Add support to Array Jobs for AWS Batch Operator (#6153) |
| - [AIRFLOW-4574] add option to provide private_key in SSHHook (#6104) (#6163) |
| - [AIRFLOW-5530] Fix typo in AWS SQS sensors (#6012) |
| - [AIRFLOW-5445] Reduce the required resources for the Kubernetes's sidecar (#6062) |
| - [AIRFLOW-5443] Use alpine image in Kubernetes's sidecar (#6059) |
| - [AIRFLOW-5344] Add --proxy-user parameter to SparkSubmitOperator (#5948) |
| - [AIRFLOW-3888] HA for Hive metastore connection (#4708) |
| - [AIRFLOW-5269] Reuse session in Scheduler Job from health endpoint (#5873) |
| - [AIRFLOW-5153] Option to force delete non-empty BQ datasets (#5768) |
| - [AIRFLOW-4443] Document LatestOnly behavior for external trigger (#5214) |
| - [AIRFLOW-2891] Make DockerOperator container_name be templateable (#5696) |
| - [AIRFLOW-2891] allow configurable docker_operator container name (#5689) |
| - [AIRFLOW-4285] Update task dependency context definition and usage (#5079) |
| - [AIRFLOW-5142] Fixed flaky Cassandra test (#5758) |
| - [AIRFLOW-5218] Less polling of AWS Batch job status (#5825) |
| - [AIRFLOW-4956] Fix LocalTaskJob heartbeat log spamming (#5589) |
| - [AIRFLOW-3160] Load latest_dagruns asynchronously on home page (#5339) |
| - [AIRFLOW-5560] Allow no confirmation on reset dags in `airflow backfill` command (#6195) |
| - [AIRFLOW-5280] conn: Remove aws_default's default region name (#5879) |
| - [AIRFLOW-5528] end_of_log_mark should not be a log record (#6159) |
| - [AIRFLOW-5526] Update docs configuration due to migration of GCP docs (#6154) |
| - [AIRFLOW-4835] Refactor operator render_template (#5461) |
| |
| Bug Fixes |
| """"""""" |
| - [AIRFLOW-5459] Use a dynamic tmp location in Dataflow operator (#6078) |
| - [Airflow 4923] Fix Databricks hook leaks API secret in logs (#5635) |
| - [AIRFLOW-5133] Keep original env state in provide_gcp_credential_file (#5747) |
| - [AIRFLOW-5497] Update docstring in ``airflow/utils/dag_processing.py`` (#6314) |
| - Revert/and then rework "[AIRFLOW-4797] Improve performance and behaviour of zombie detection (#5511)" to improve performance (#5908) |
| - [AIRFLOW-5634] Don't allow editing of DagModelView (#6308) |
| - [AIRFLOW-4309] Remove Broken Dag error after Dag is deleted (#6102) |
| - [AIRFLOW-5387] Fix "show paused" pagination bug (#6100) |
| - [AIRFLOW-5489] Remove unneeded assignment of variable (#6106) |
| - [AIRFLOW-5491] mark_tasks pydoc is incorrect (#6108) |
| - [AIRFLOW-5492] added missing docstrings (#6107) |
| - [AIRFLOW-5503] Fix tree view layout on HDPI screen (#6125) |
| - [AIRFLOW-5481] Allow Deleting Renamed DAGs (#6101) |
| - [AIRFLOW-3857] spark_submit_hook cannot kill driver pod in Kubernetes (#4678) |
| - [AIRFLOW-4391] Fix tooltip for None-State Tasks in 'Recent Tasks' (#5909) |
| - [AIRFLOW-5554] Require statsd 3.3.0 minimum (#6185) |
| - [AIRFLOW-5306] Fix the display of links when they contain special characters (#5904) |
| - [AIRFLOW-3705] Fix PostgresHook get_conn to use conn_name_attr (#5841) |
| - [AIRFLOW-5581] Cleanly shutdown KubernetesJobWatcher for safe Scheduler shutdown on SIGTERM (#6237) |
| - [AIRFLOW-5634] Don't allow disabled fields to be edited in DagModelView (#6307) |
| - [AIRFLOW-4833] Allow to set Jinja env options in DAG declaration (#5943) |
| - [AIRFLOW-5408] Fix env variable name in Kubernetes template (#6016) |
| - [AIRFLOW-5102] Worker jobs should terminate themselves if they can't heartbeat (#6284) |
| - [AIRFLOW-5572] Clear task reschedules when clearing task instances (#6217) |
| - [AIRFLOW-5543] Fix tooltip disappears in tree and graph view (RBAC UI) (#6174) |
| - [AIRFLOW-5444] Fix action_logging so that request.form for POST is logged (#6064) |
| - [AIRFLOW-5484] fix PigCliHook has incorrect named parameter (#6112) |
| - [AIRFLOW-5342] Fix MSSQL breaking task_instance db migration (#6014) |
| - [AIRFLOW-5556] Add separate config for timeout from scheduler dag processing (#6186) |
| - [AIRFLOW-4858] Deprecate "Historical convenience functions" in airflow.configuration (#5495) (#6144) |
| - [AIRFLOW-774] Fix long-broken DAG parsing Statsd metrics (#6157) |
| - [AIRFLOW-5419] Use ``sudo`` to kill cleared tasks when running with impersonation (#6026) (#6176) |
| - [AIRFLOW-5537] Yamllint is not needed as dependency on host |
| - [AIRFLOW-5536] Better handling of temporary output files |
| - [AIRFLOW-5535] Fix name of VERBOSE parameter |
| - [AIRFLOW-5519] Fix sql_to_gcs operator missing multi-level default args by adding apply_defaults decorator (#6146) |
| - [AIRFLOW-5210] Make finding template files more efficient (#5815) |
| - [AIRFLOW-5447] Scheduler stalls because second watcher thread in default args (#6129) |
| |
| Doc-only changes |
| """""""""""""""" |
| - [AIRFLOW-5574] Fix Google Analytics script loading (#6218) |
| - [AIRFLOW-5588] Add Celery's architecture diagram (#6247) |
| - [AIRFLOW-5521] Fix link to GCP documentation (#6150) |
| - [AIRFLOW-5398] Update contrib example DAGs to context manager (#5998) |
| - [AIRFLOW-5268] Apply same DAG naming conventions as in literature (#5874) |
| - [AIRFLOW-5101] Fix inconsistent owner value in examples (#5712) |
| - [AIRFLOW-XXX] Fix typo - AWS DynamoDB Hook (#6319) |
| - [AIRFLOW-XXX] Fix Documentation for adding extra Operator Links (#6301) |
| - [AIRFLOW-XXX] Add section on task lifecycle & correct casing in docs (#4681) |
| - [AIRFLOW-XXX] Make it clear that 1.10.5 was not accidentally omitted from UPDATING.md (#6240) |
| - [AIRFLOW-XXX] Improve format in code-block directives (#6242) |
| - [AIRFLOW-XXX] Format Sendgrid docs (#6245) |
| - [AIRFLOW-XXX] Update to new logo (#6066) |
| - [AIRFLOW-XXX] Typo in FAQ - schedule_interval (#6291) |
| - [AIRFLOW-XXX] Add message about breaking change in DAG#get_task_instances in 1.10.4 (#6226) |
| - [AIRFLOW-XXX] Fix incorrect units in docs for metrics using Timers (#6152) |
| - [AIRFLOW-XXX] Fix backtick issues in .rst files & Add Precommit hook (#6162) |
| - [AIRFLOW-XXX] Update documentation about variables forcing answer (#6158) |
| - [AIRFLOW-XXX] Add a third way to configure authorization (#6134) |
| - [AIRFLOW-XXX] Add example of running pre-commit hooks on single file (#6143) |
| - [AIRFLOW-XXX] Add information about default pool to docs (#6019) |
| - [AIRFLOW-XXX] Make Breeze The default integration test environment (#6001) |
| |
| Misc/Internal |
| """"""""""""" |
| - [AIRFLOW-5687] Upgrade pip to 19.0.2 in CI build pipeline (#6358) (#6361) |
| - [AIRFLOW-5533] Fixed failing CRON build (#6167) |
| - [AIRFLOW-5130] Use GOOGLE_APPLICATION_CREDENTIALS constant from library (#5744) |
| - [AIRFLOW-5369] Adds interactivity to pre-commits (#5976) |
| - [AIRFLOW-5531] Replace deprecated log.warn() with log.warning() (#6165) |
| - [AIRFLOW-4686] Make dags Pylint compatible (#5753) |
| - [AIRFLOW-4864] Remove calls to load_test_config (#5502) |
| - [AIRFLOW-XXX] Pin version of mypy so we are stable over time (#6198) |
| - [AIRFLOW-XXX] Add tests that got missed from #5127 |
| - [AIRFLOW-4928] Move config parses to class properties inside DagBag (#5557) |
| - [AIRFLOW-5003] Making AWS Hooks pylint compatible (#5627) |
| - [AIRFLOW-5580] Add base class for system test (#6229) |
| |
| Airflow 1.10.5, 2019-09-04 |
| -------------------------- |
| |
| New Features |
| """""""""""" |
| - [AIRFLOW-1498] Add feature for users to add Google Analytics to Airflow UI (#5850) |
| - [AIRFLOW-4074] Add option to add labels to Dataproc jobs (#5606) |
| - [AIRFLOW-4846] Allow specification of an existing secret containing git credentials for init containers (#5475) |
| |
| Improvements |
| """""""""""" |
| - [AIRFLOW-5335] Update GCSHook methods so they need min IAM perms (#5939) |
| - [AIRFLOW-2692] Allow AWS Batch Operator to use templates in job_name parameter (#3557) |
| - [AIRFLOW-4768] Add Timeout parameter in example_gcp_video_intelligence (#5862) |
| - [AIRFLOW-5165] Make Dataproc highly available (#5781) |
| - [AIRFLOW-5139] Allow custom ES configs (#5760) |
| - [AIRFLOW-5340] Fix GCP DLP example (#594) |
| - [AIRFLOW-5211] Add pass_value to template_fields BigQueryValueCheckOperator (#5816) |
| - [AIRFLOW-5113] Support icon url in slack web hook (#5724) |
| - [AIRFLOW-4230] bigquery schema update options should be a list (#5766) |
| - [AIRFLOW-1523] Clicking on Graph View should display related DAG run (#5866) |
| - [AIRFLOW-5027] Generalized CloudWatch log grabbing for ECS and SageMaker operators (#5645) |
| - [AIRFLOW-5244] Add all possible themes to default_webserver_config.py (#5849) |
| - [AIRFLOW-5245] Add more metrics around the scheduler (#5853) |
| - [AIRFLOW-5048] Improve display of Kubernetes resources (#5665) |
| - [AIRFLOW-5284] Replace deprecated log.warn by log.warning (#5881) |
| - [AIRFLOW-5276] Remove unused helpers from airflow.utils.helpers (#5878) |
| - [AIRFLOW-4316] Support setting kubernetes_environment_variables config section from env var (#5668) |
| |
| Bug fixes |
| """"""""" |
| - [AIRFLOW-5168] Fix Dataproc operators that failed in 1.10.4 (#5928) |
| - [AIRFLOW-5136] Fix Bug with Incorrect template_fields in DataProc{*} Operators (#5751) |
| - [AIRFLOW-5169] Pass GCP Project ID explicitly to StorageClient in GCSHook (#5783) |
| - [AIRFLOW-5302] Fix bug in none_skipped Trigger Rule (#5902) |
| - [AIRFLOW-5350] Fix bug in the num_retires field in BigQueryHook (#5955) |
| - [AIRFLOW-5145] Fix rbac ui presents false choice to encrypt or not encrypt variable values (#5761) |
| - [AIRFLOW-5104] Set default schedule for GCP Transfer operators (#5726) |
| - [AIRFLOW-4462] Use datetime2 column types when using MSSQL backend (#5707) |
| - [AIRFLOW-5282] Add default timeout on kubeclient & catch HTTPError (#5880) |
| - [AIRFLOW-5315] TaskInstance not updating from DB when user changes executor_config (#5926) |
| - [AIRFLOW-4013] Mark success/failed is picking all execution date (#5616) |
| - [AIRFLOW-5152] Fix autodetect default value in GoogleCloudStorageToBigQueryOperator(#5771) |
| - [AIRFLOW-5100] Airflow scheduler does not respect safe mode setting (#5757) |
| - [AIRFLOW-4763] Allow list in DockerOperator.command (#5408) |
| - [AIRFLOW-5260] Allow empty uri arguments in connection strings (#5855) |
| - [AIRFLOW-5257] Fix ElasticSearch log handler errors when attempting to close logs (#5863) |
| - [AIRFLOW-1772] Google Updated Sensor doesn't work with CRON expressions (#5730) |
| - [AIRFLOW-5085] When you run kubernetes git-sync test from TAG, it fails (#5699) |
| - [AIRFLOW-5258] ElasticSearch log handler, has 2 times of hours (%H and %I) in _clean_execution_dat (#5864) |
| - [AIRFLOW-5348] Escape Label in deprecated chart view when set via JS (#5952) |
| - [AIRFLOW-5357] Fix Content-Type for exported variables.json file (#5963) |
| - [AIRFLOW-5109] Fix process races when killing processes (#5721) |
| - [AIRFLOW-5240] Latest version of Kombu is breaking Airflow for py2 |
| |
| Misc/Internal |
| """"""""""""" |
| - [AIRFLOW-5111] Remove apt-get upgrade from the Dockerfile (#5722) |
| - [AIRFLOW-5209] Fix Documentation build (#5814) |
| - [AIRFLOW-5083] Check licence image building can be faster and moved to before-install (#5695) |
| - [AIRFLOW-5119] Cron job should always rebuild everything from scratch (#5733) |
| - [AIRFLOW-5108] In the CI local environment long-running kerberos might fail sometimes (#5719) |
| - [AIRFLOW-5092] Latest Python image should be pulled locally in force_pull_and_build (#5705) |
| - [AIRFLOW-5225] Consistent licences can be added automatically for all JS files (#5827) |
| - [AIRFLOW-5229] Add licence to all other file types (#5831) |
| - [AIRFLOW-5227] Consistent licences for all .sql files (#5829) |
| - [AIRFLOW-5161] Add pre-commit hooks to run static checks for only changed files (#5777) |
| - [AIRFLOW-5159] Optimise checklicence image build (do not build if not needed) (#5774) |
| - [AIRFLOW-5263] Show diff on failure of pre-commit checks (#5869) |
| - [AIRFLOW-5204] Shell files should be checked with shellcheck and have identical licence (#5807) |
| - [AIRFLOW-5233] Check for consistency in whitespace (tabs/eols) and common problems (#5835) |
| - [AIRFLOW-5247] Getting all dependencies from NPM can be moved up in Dockerfile (#5870) |
| - [AIRFLOW-5143] Corrupted rat.jar became part of the Docker image (#5759) |
| - [AIRFLOW-5226] Consistent licences for all html JINJA templates (#5828) |
| - [AIRFLOW-5051] Coverage is not properly reported in the new CI system (#5732) |
| - [AIRFLOW-5239] Small typo and incorrect tests in CONTRIBUTING.md (#5844) |
| - [AIRFLOW-5287] Checklicence base image is not pulled (#5886) |
| - [AIRFLOW-5301] Some not-yet-available files from breeze are committed to master (#5901) |
| - [AIRFLOW-5285] Pre-commit pylint runs over todo files (#5884) |
| - [AIRFLOW-5288] Temporary container for static checks should be auto-removed (#5887) |
| - [AIRFLOW-5206] All .md files should have all common licence, TOC (where applicable) (#5809) |
| - [AIRFLOW-5329] Easy way to add local files to docker (#5933) |
| - [AIRFLOW-4027] Make experimental api tests more stateless (#4854) |
| |
| Doc-only changes |
| """""""""""""""" |
| - [AIRFLOW-XXX] Fixed Azkaban link (#5865) |
| - [AIRFLOW-XXX] Remove duplicate lines from CONTRIBUTING.md (#5830) |
| - [AIRFLOW-XXX] Fix incorrect docstring parameter in SchedulerJob (#5729) |
| |
| Airflow 1.10.4, 2019-08-06 |
| -------------------------- |
| |
| New Features |
| """""""""""" |
| - [AIRFLOW-4811] Implement GCP Data Loss Prevention Hook and Operators (#5539) |
| - [AIRFLOW-5035] Replace multiprocessing.Manager with a golang-"channel" style (#5615) |
| - [AIRFLOW-4883] Kill hung file process managers (#5605) |
| - [AIRFLOW-4929] Pretty print JSON Variables in UI (#5573) |
| - [AIRFLOW-4884] Roll up import_errors in RBAC UI (#5516) |
| - [AIRFLOW-4871] Allow creating DagRuns via RBAC UI (#5507) |
| - [AIRFLOW-4591] Make default_pool a real pool (#5349) |
| - [AIRFLOW-4844] Add optional is_paused_upon_creation argument to DAG (#5473) |
| - [AIRFLOW-4456] Add sub-classable BaseBranchOperator (#5231) |
| - [AIRFLOW-4343] Show warning in UI if scheduler is not running (#5127) |
| - [AIRFLOW-4739] Add ability to arbitrarily define kubernetes worker pod labels (#5376) |
| - [AIRFLOW-4348] Add GCP console link in BigQueryOperator (#5195) |
| - [AIRFLOW-4306] Global operator extra links (#5094) |
| - [AIRFLOW-4812] Add batch images annotation (#5433) |
| - [AIRFLOW-4135] Add Google Cloud Build operator and hook (#5251) |
| - [AIRFLOW-4781] Add the ability to specify ports in KubernetesPodOperator (#5410) |
| - [AIRFLOW-4521] Pause dag also pause its subdags (#5283) |
| - [AIRFLOW-4738] Enforce exampleinclude for example DAGs (#5375) |
| - [AIRFLOW-4326] Airflow AWS SQS Operator (#5110) |
| - [AIRFLOW-3729] Support `DownwardAPI` in env variables for KubernetesPodOperator (#4554) |
| - [AIRFLOW-4585] Implement Kubernetes Pod Mutation Hook (#5359) |
| - [AIRFLOW-161] New redirect route and extra links (#5059) |
| - [AIRFLOW-4420] Backfill respects task_concurrency (#5221) |
| - [AIRFLOW-4147] Add Operator to publish event to Redis (#4967) |
| - [AIRFLOW-3359] Add option to pass customer encryption keys to Dataproc (#4200) |
| - [AIRFLOW-4318] Create Google Cloud Translate Speech Operator (#5102) |
| - [AIRFLOW-3960] Adds Google Cloud Speech operators (#4780) |
| - [AIRFLOW-1501] Add GoogleCloudStorageDeleteOperator (#5230) |
| - [AIRFLOW-3672] Add support for Mongo DB DNS Seedlist Connection Format (#4481) |
| - [AIRFLOW-4397] add integrations docs manually for gcs sensors (#5204) |
| - [AIRFLOW-4251] Instrument DagRun schedule delay (#5050) |
| - [AIRFLOW-4118] instrument DagRun duration (#4946) |
| - [AIRFLOW-4361] Fix flaky test_integration_run_dag_with_scheduler_failure (#5182) |
| - [AIRFLOW-4361] Fix flaky test_integration_run_dag_with_scheduler_failure (#5140) |
| - [AIRFLOW-4168] Create Google Cloud Video Intelligence Operators (#4985) |
| - [AIRFLOW-4397] Add GCSUploadSessionCompleteSensor (#5166) |
| - [AIRFLOW-4335] Add default num_retries to GCP connection (#5117) |
| - [AIRFLOW-3808] Add cluster_fields to BigQueryHook's create_empty_table (#4654) |
| - [AIRFLOW-4362] Fix test_execution_limited_parallelism (#5141) |
| - [AIRFLOW-4307] Backfill respects concurrency limit (#5128) |
| - [AIRFLOW-4268] Add MsSqlToGoogleCloudStorageOperator (#5077) |
| - [AIRFLOW-4169] Add Google Cloud Vision Detect Operators (#4986) |
| - [AIRFLOW-XXX] Fix WS-2019-0032 (#5384) |
| - [AIRFLOW-XXX] Fix CVE-2019-11358 (#5197) |
| - [AIRFLOW-XXX] Change allowed version of Jinja2 to fix CVE-2019-10906 (#5075) |
| |
| Improvement |
| """"""""""" |
| - [AIRFLOW-5022] Fix DockerHook for registries with port numbers (#5644) |
| - [AIRFLOW-4961] Insert TaskFail.duration as int match DB schema column type (#5593) |
| - [AIRFLOW-5038] skip pod deleted log message when pod deletion is disabled (#5656) |
| - [AIRFLOW-5067] Update pagination symbols (#5682) |
| - [AIRFLOW-4981][AIRFLOW-4788] Always use pendulum DateTimes in task instance context (#5654) |
| - [AIRFLOW-4880] Add success, failure and fail_on_empty params to SqlSensor (#5488) |
| - [AIRFLOW-3617] Add gpu limits option in configurations for Kube executor and pod (#5643) |
| - [AIRFLOW-4998] Run multiple queries in BigQueryOperator (#5619) |
| - [AIRFLOW-4929] Improve display of JSON Variables in UI (#5641) |
| - [AIRFLOW-4959] Add .hql support for the DataProcHiveOperator (#5591) |
| - [AIRFLOW-4962] Fix Werkzeug v0.15 deprecation notice for DispatcherMiddleware import (#5595) |
| - [AIRFLOW-4797] Improve performance and behaviour of zombie detection (#5511) |
| - [AIRFLOW-4911] Silence the FORBIDDEN errors from the KubernetesExecutor (#5547) |
| - [AIRFLOW-3495] Validate one of query and query_uri passed to DataProcSparkSqlOperator (#5510) |
| - [AIRFLOW-4925] Improve css style for Variables Import file field (#5552) |
| - [AIRFLOW-4906] Improve debugging for the SparkSubmitHook (#5542) |
| - [AIRFLOW-4904] unittest.cfg name and path can be overridden by setting $AIRFLOW_TEST_CONFIG (#5540) |
| - [AIRFLOW-4920] Use html.escape instead of cgi.escape to fix DeprecationWarning (#5551) |
| - [AIRFLOW-4919] DataProcJobBaseOperator dataproc_*_properties templated (#5555) |
| - [AIRFLOW-4478] Lazily instantiate default resources objects. (#5259) |
| - [AIRFLOW-4564] AzureContainerInstance bugfixes and improvements (#5319) |
| - [AIRFLOW-4237] Including Try Number of Task in Gantt Chart (#5037) |
| - [AIRFLOW-4862] Allow directly using IP address as hostname for webserver logs (#5501) |
| - [AIRFLOW-4857] Add templated fields to SlackWebhookOperator (#5490) |
| - [AIRFLOW-3502] Add Celery config option for setting "pool" (#4308) |
| - [AIRFLOW-3217] Button to toggle line wrapping in log and code views (#4277) |
| - [AIRFLOW-4491] Add a "Jump to end" button for logs (#5266) |
| - [AIRFLOW-4422] Pool utilization stats (#5453) |
| - [AIRFLOW-4805] Add py_file as templated field in DataflowPythonOperator (#5451) |
| - [AIRFLOW-4838] Surface Athena errors in AWSAthenaOperator (#5467) |
| - [AIRFLOW-4831] conf.has_option no longer throws if section is missing. (#5455) |
| - [AIRFLOW-4829] More descriptive exceptions for EMR sensors (#5452) |
| - [AIRFLOW-4414] AWSAthenaOperator: Push QueryExecutionID to XCom (#5276) |
| - [AIRFLOW-4791] add "schema" keyword arg to SnowflakeOperator (#5415) |
| - [AIRFLOW-4759] Don't error when marking successful run as failed (#5435) |
| - [AIRFLOW-4716] Instrument dag loading time duration (#5350) |
| - [AIRFLOW-3958] Support list tasks as upstream in chain (#4779) |
| - [AIRFLOW-4409] Prevent task duration break by null value (#5178) |
| - [AIRFLOW-4418] Add "failed only" option to task modal (#5193) |
| - [AIRFLOW-4740] Accept string ``end_date`` in DAG default_args (#5381) |
| - [AIRFLOW-4423] Improve date handling in mysql to gcs operator. (#5196) |
| - [AIRFLOW-4447] Display task duration as human friendly format in UI (#5218) |
| - [AIRFLOW-4377] Remove needless object conversion in DAG.owner() (#5144) |
| - [AIRFLOW-4766] Add autoscaling option for DataprocClusterCreateOperator (#5425) |
| - [AIRFLOW-4795] Upgrade alembic to latest release. (#5411) |
| - [AIRFLOW-4793] Add signature_name to mlengine operator (#5417) |
| - [AIRFLOW-3211] Reattach to GCP Dataproc jobs upon Airflow restart (#4083) |
| - [AIRFLOW-4750] Log identified zombie task instances (#5389) |
| - [AIRFLOW-3870] STFPOperator: Update log level and return value (#4355) |
| - [AIRFLOW-4759] Batch queries in set_state API. (#5403) |
| - [AIRFLOW-2737] Restore original license header to airflow.api.auth.backend.kerberos_auth |
| - [AIRFLOW-3635] Fix incorrect logic in delete_dag (introduced in PR#4406) (#4445) |
| - [AIRFLOW-3599] Removed Dagbag from delete dag (#4406) |
| - [AIRFLOW-4737] Increase and document celery queue name limit (#5383) |
| - [AIRFLOW-4505] Correct Tag ALL for PY3 (#5275) |
| - [AIRFLOW-4743] Add environment variables support to SSHOperator (#5385) |
| - [AIRFLOW-4725] Fix setup.py PEP440 & Sphinx-PyPI-upload dependency (#5363) |
| - [AIRFLOW-3370] Add stdout output options to Elasticsearch task log handler (#5048) |
| - [AIRFLOW-4396] Provide a link to external Elasticsearch logs in UI. (#5164) |
| - [AIRFLOW-1381] Allow setting host temporary directory in DockerOperator (#5369) |
| - [AIRFLOW-4598] Task retries are not exhausted for K8s executor (#5347) |
| - [AIRFLOW-4218] Support to Provide http args to K8executor while calling k8 Python client lib apis (#5060) |
| - [AIRFLOW-4159] Add support for additional static pod labels for K8sExecutor (#5134) |
| - [AIRFLOW-4720] Allow comments in .airflowignore files. (#5355) |
| - [AIRFLOW-4486] Add AWS IAM authentication in MySqlHook (#5334) |
| - [AIRFLOW-4417] Add AWS IAM authentication for PostgresHook (#5223) |
| - [AIRFLOW-3990] Compile regular expressions. (#4813) |
| - [AIRFLOW-4572] Rename prepare_classpath() to prepare_syspath() (#5328) |
| - [AIRFLOW-3869] Raise consistent exception in AirflowConfigParser.getboolean (#4692) |
| - [AIRFLOW-4571] Add headers to templated field for SimpleHttpOperator (#5326) |
| - [AIRFLOW-3867] Rename GCP's subpackage (#4690) |
| - [AIRFLOW-3725] Add private_key to bigquery_hook get_pandas_df (#4549) |
| - [AIRFLOW-4546] Upgrade google-cloud-bigtable. (#5307) |
| - [AIRFLOW-4519] Optimise operator classname sorting in views (#5282) |
| - [AIRFLOW-4503] Support fully pig options (#5271) |
| - [AIRFLOW-4468] add sql_alchemy_max_overflow parameter (#5249) |
| - [AIRFLOW-4467] Add dataproc_jars to templated fields in Dataproc oper… (#5248) |
| - [AIRFLOW-4381] Use get_direct_relative_ids get task relatives (#5147) |
| - [AIRFLOW-3624] Add masterType parameter to MLEngineTrainingOperator (#4428) |
| - [AIRFLOW-3143] Support Auto-Zone in DataprocClusterCreateOperator (#5169) |
| - [AIRFLOW-3874] Improve BigQueryHook.run_with_configuration's location support (#4695) |
| - [AIRFLOW-4399] Avoid duplicated os.path.isfile() check in models.dagbag (#5165) |
| - [AIRFLOW-4031] Allow for key pair auth in snowflake hook (#4875) |
| - [AIRFLOW-3901] add role as optional config parameter for SnowflakeHook (#4721) |
| - [AIRFLOW-3455] add region in snowflake connector (#4285) |
| - [AIRFLOW-4073] add template_ext for AWS Athena operator (#4907) |
| - [AIRFLOW-4093] AWSAthenaOperator: Throw exception if job failed/cancelled/reach max retries (#4919) |
| - [AIRFLOW-4356] Add extra RuntimeEnvironment keys to DataFlowHook (#5149) |
| - [AIRFLOW-4337] Fix docker-compose deprecation warning in CI (#5119) |
| - [AIRFLOW-3603] QuboleOperator: Remove SQLCommand from SparkCmd documentation (#4411) |
| - [AIRFLOW-4328] Fix link to task instances from Pool page (#5124) |
| - [AIRFLOW-4255] Make GCS Hook Backwards compatible (#5089) |
| - [AIRFLOW-4103] Allow uppercase letters in dataflow job names (#4925) |
| - [AIRFLOW-4255] Replace Discovery based api with client based for GCS (#5054) |
| - [AIRFLOW-4311] Remove sleep in localexecutor (#5096) |
| - [AIRFLOW-2836] Minor improvement-contrib.sensors.FileSensor (#3674) |
| - [AIRFLOW-4104] Add type annotations to common classes. (#4926) |
| - [AIRFLOW-3910] Raise exception explicitly in Connection.get_hook() (#4728) |
| - [AIRFLOW-3322] Update QuboleHook to fetch args dynamically from qds_sdk (#4165) |
| - [AIRFLOW-4565] instrument celery executor (#5321) |
| - [AIRFLOW-4573] Import airflow_local_settings after prepare_classpath (#5330) |
| - [AIRFLOW-4448] Don't bake ENV and _cmd into tmp config for non-sudo (#4050) |
| - [AIRFLOW-4295] Make ``method`` attribute case insensitive in HttpHook (#5313) |
| - [AIRFLOW-3703] Add dnsPolicy option for KubernetesPodOperator (#4520) |
| - [AIRFLOW-3057] add prev_*_date_success to template context (#5372) |
| - [AIRFLOW-4336] Stop showing entire GCS files bytes in log for gcs_download_operator (#5151) |
| - [AIRFLOW-4528] Cancel DataProc task on timeout (#5293) |
| |
| Bug fixes |
| """"""""" |
| - [AIRFLOW-5089] Change version requirement on google-cloud-spanner to work around version incompatibility (#5703) |
| - [AIRFLOW-4289] fix spark_binary argument being ignored in SparkSubmitHook (#5564) |
| - [AIRFLOW-5075] Let HttpHook handle connections with empty host fields (#5686) |
| - [AIRFLOW-4822] Fix bug where parent-dag task instances are wrongly cleared when using subdags (#5444) |
| - [AIRFLOW-5050] Correctly delete FAB permission m2m objects in ``airflow sync_perms`` (#5679) |
| - [AIRFLOW-5030] fix env var expansion for config key contains __ (#5650) |
| - [AIRFLOW-4590] changing log level to be proper library to suppress warning in WinRM (#5337) |
| - [AIRFLOW-4451] Allow named tuples to be templated (#5673) |
| - [AIRFLOW-XXX] Fix bug where Kube pod limits were not applied (requests were, but not limits) (#5657) |
| - [AIRFLOW-4775] Fix incorrect parameter order in GceHook (#5613) |
| - [AIRFLOW-4995] Fix DB initialisation on MySQL >=8.0.16 (#5614) |
| - [AIRFLOW-4934] Fix ProxyFix due to Werkzeug upgrade (#5563) (#5571) |
| - [AIRFLOW-4136] fix key_file of hook is overwritten by SSHHook connection (#5558) |
| - [AIRFLOW-4587] Replace self.conn with self.get_conn() in AWSAthenaHook (#5545) |
| - [AIRFLOW-1740] Fix xcom creation and update via UI (#5530) (#5531) |
| - [AIRFLOW-4900] Resolve incompatible version of Werkzeug (#5535) |
| - [AIRFLOW-4510] Don't mutate default_args during DAG initialization (#5277) |
| - [AIRFLOW-3360] Make the DAGs search respect other querystring parameters with url-search-params-polyfill for IE support (#5503) |
| - [AIRFLOW-4896] Make KubernetesExecutorConfig's default args immutable (#5534) |
| - [AIRFLOW-4494] Remove ``shell=True`` in DaskExecutor (#5273) |
| - [AIRFLOW-4890] Fix Log link in TaskInstance's View for Non-RBAC (#5525) |
| - [AIRFLOW-4892] Fix connection creation via UIs (#5527) |
| - [AIRFLOW-4406] Fix a method name typo: NullFernet.decrpyt to decrypt (#5509) |
| - [AIRFLOW-4849] Add gcp_conn_id to cloudsqldatabehook class to use correctly CloudSqlProxyRunner class (#5478) |
| - [AIRFLOW-4769] Pass gcp_conn_id to BigtableHook (#5445) |
| - [AIRFLOW-4524] Fix incorrect field names in view for Mark Success/Failure (#5486) |
| - [AIRFLOW-3671] Remove arg ``replace`` of MongoToS3Operator from ``kwargs`` (#4480) |
| - [AIRFLOW-4845] Fix bug where runAsUser 0 doesn't get set in k8s security context (#5474) |
| - [AIRFLOW-4354] Fix exception in "between" date filter in classic UI (#5480) |
| - [AIRFLOW-4587] Replace self.conn with self.get_conn() in AWSAthenaHook (#5462) |
| - [AIRFLOW-4516] K8s runAsUser and fsGroup cannot be strings (#5429) |
| - [AIRFLOW-4298] Stop Scheduler repeatedly warning "connection invalidated" (#5470) |
| - [AIRFLOW-4559] JenkinsJobTriggerOperator bugfix (#5318) |
| - [AIRFLOW-4841] Pin Sphinx AutoApi to 1.0.0 (#5468) |
| - [AIRFLOW-4479] Include s3_overwrite kwarg in load_bytes method (#5312) |
| - [AIRFLOW-3746] Fix DockerOperator missing container exit (#4583) |
| - [AIRFLOW-4233] Remove Template Extension from Bq to GCS Operator (#5456) |
| - [AIRFLOW-2141][AIRFLOW-3157][AIRFLOW-4170] Serialize non-str value by JSON when importing Variables (#4991) |
| - [AIRFLOW-4826] Remove warning from ``airflow resetdb`` command (#5447) |
| - [AIRFLOW-4148] Fix editing DagRuns when clicking state column (#5436) |
| - [AIRFLOW-4455] dag_details broken for subdags in RBAC UI (#5234) |
| - [AIRFLOW-2955] Fix kubernetes pod operator to set requests and limits on task pods (#4551) |
| - [AIRFLOW-4459] Fix wrong DAG count in /home page when DAG count is zero (#5235) |
| - [AIRFLOW-3876] AttributeError: module `distutils` has no attribute 'util' |
| - [AIRFLOW-4146] Fix CgroupTaskRunner errors (#5224) |
| - [AIRFLOW-4524] Fix bug with "Ignore \*" toggles in RBAC mode (#5378) |
| - [AIRFLOW-4765] Fix DataProcPigOperator execute method (#5426) |
| - [AIRFLOW-4798] Obviate interdependencies for dagbag and TI tests (#5422) |
| - [AIRFLOW-4800] Fix GKEClusterHook ctor calls (#5424) |
| - [AIRFLOW-4799] Don't mutate self.env in BashOperator execute method (#5421) |
| - [AIRFLOW-4393] Add retry logic when fetching pod status and/or logs in KubernetesPodOperator (#5284) |
| - [AIRFLOW-4174] Fix HttpHook run with backoff (#5213) |
| - [AIRFLOW-4463] Handle divide-by-zero errors in short retry intervals (#5243) |
| - [AIRFLOW-2614] Speed up trigger_dag API call when lots of DAGs in system |
| - [AIRFLOW-4756] add ti.state to ti.start_date as criteria for gantt (#5399) |
| - [AIRFLOW-4760] Fix zip-packaged DAGs disappearing from DagBag when reloaded (#5404) |
| - [AIRFLOW-4731] Fix GCS hook with google-storage-client 1.16 (#5368) |
| - [AIRFLOW-3506] use match_phrase to query log_id in elasticsearch (#4342) |
| - [AIRFLOW-4084] fix ElasticSearch log download (#5177) |
| - [AIRFLOW-4501] Register pendulum datetime converter for sqla+pymysql (#5190) |
| - [AIRFLOW-986] HiveCliHook ignores 'proxy_user' value in a connection's extra parameter (#5305) |
| - [AIRFLOW-4442] fix hive_tblproperties in HiveToDruidTransfer (#5211) |
| - [AIRFLOW-4557] Add gcp_conn_id parameter to get_sqlproxy_runner() of CloudSqlDatabaseHook (#5314) |
| - [AIRFLOW-4545] Upgrade FAB to latest version (#4955) |
| - [AIRFLOW-4492] Change Dataproc Cluster operators to poll Operations (#5269) |
| - [AIRFLOW-4452] Webserver and Scheduler keep crashing because of slackclient update (#5225) |
| - [AIRFLOW-4450] Fix request arguments in has_dag_access (#5220) |
| - [AIRFLOW-4434] Support Impala with the HiveServer2Hook (#5206) |
| - [AIRFLOW-3449] Write local dag parsing logs when remote logging enabled. (#5175) |
| - [AIRFLOW-4300] Fix graph modal call when DAG has not yet run (#5185) |
| - [AIRFLOW-4401] Use managers for Queue synchronization (#5200) |
| - [AIRFLOW-3626] Fixed triggering DAGs contained within zip files (#4439) |
| - [AIRFLOW-3720] Fix mismatch while comparing GCS and S3 files (#4766) |
| - [AIRFLOW-4403] search by ``dag_id`` or ``owners`` in UI (#5184) |
| - [AIRFLOW-4308] Fix TZ-loop around DST on Python 3.6+ (#5095) |
| - [AIRFLOW-4324] fix DAG fuzzy search in RBAC UI (#5131) |
| - [AIRFLOW-4297] Temporary hot fix on manage_slas() for 1.10.4 release (#5150) |
| - [AIRFLOW-4299] Upgrade to Celery 4.3.0 to fix crashing workers (#5116) |
| - [AIRFLOW-4291] Correctly render doc_md in DAG graph page (#5121) |
| - [AIRFLOW-4310] Fix incorrect link on Dag Details page (#5122) |
| - [AIRFLOW-4331] Correct filter for Null-state runs from Dag Detail page (#5123) |
| - [AIRFLOW-4294] Fix missing dag & task runs in UI dag_id contains a dot (#5111) |
| - [AIRFLOW-4332] Upgrade sqlalchemy to remove security Vulnerability (#5113) |
| - [AIRFLOW-4312] Add template_fields & template_ext to BigQueryCheckO… (#5097) |
| - [AIRFLOW-4293] Fix downgrade in d4ecb8fbee3_add_schedule_interval_to_dag.py (#5086) |
| - [AIRFLOW-4267] Fix TI duration in Graph View (#5071) |
| - [AIRFLOW-4163] IntervalCheckOperator supports relative diff and not ignore 0 (#4983) |
| - [AIRFLOW-3938] QuboleOperator Fixes and Support for SqlCommand (#4832) |
| - [AIRFLOW-2903] Change default owner to ``airflow`` (#4151) |
| - [AIRFLOW-4136] Fix overwrite of key_file by constructor (#5155) |
| - [AIRFLOW-3241] Remove Invalid template ext in GCS Sensors (#4076) |
| |
| Misc/Internal |
| """"""""""""" |
| - [AIRFLOW-4338] Change k8s pod_request_factory to use yaml safe_load (#5120) |
| - [AIRFLOW-4869] Reorganize sql to gcs operators. (#5504) |
| - [AIRFLOW-5021] move gitpython into setup_requires (#5640) |
| - [AIRFLOW-4583] Fixes type error in GKEPodOperator (#5612) |
| - [AIRFLOW-4116] Dockerfile now supports CI image build on DockerHub (#4937) |
| - [AIRFLOW-4115] Multi-staging Airflow Docker image (#4936) |
| - [AIRFLOW-4963] Avoid recreating task context (#5596) |
| - [AIRFLOW-4865] Add context manager to set temporary config values in tests. (#5569) |
| - [AIRFLOW-4937] Fix lodash security issue with version below 4.17.13 (#5572) (used only in build-pipeline, not runtime) |
| - [AIRFLOW-4868] Fix typo in kubernetes/docker/build.sh (#5505) |
| - [AIRFLOW-4211] Add tests for WebHDFSHook (#5015) |
| - [AIRFLOW-4320] Add tests for SegmentTrackEventOperator (#5104) |
| - [AIRFLOW-4319] Add tests for Bigquery related Operators (#5101) |
| - [AIRFLOW-4014] Change DatastoreHook and add tests (#4842) |
| - [AIRFLOW-4322] Add test for VerticaOperator (#5107) |
| - [AIRFLOW-4323] Add 2 tests for WinRMOperator (#5108) |
| - [AIRFLOW-3677] Improve CheckOperator test coverage (#4756) |
| - [AIRFLOW-4659] Fix pylint problems for api module (#5398) |
| - [AIRFLOW-4358] Speed up test_jobs by not running tasks (#5162) |
| - [AIRFLOW-4394] Don't test behaviour of BackfillJob from CLI tests (#5160) |
| - [AIRFLOW-3471] Move XCom out of models.py (#4629) |
| - [AIRFLOW-4379] Remove duplicate code & Add validation in gcs_to_gcs.py (#5145) |
| - [AIRFLOW-4259] Move models out of models.py (#5056) |
| - [AIRFLOW-XXX] Speed up building of Cassanda module on Travis (#5233) |
| - [AIRFLOW-4535] Break jobs.py into multiple files (#5303) |
| - [AIRFLOW-1464] Batch update task_instance state (#5323) |
| - [AIRFLOW-4554] Test for sudo command, add some other test docs (#5310) |
| - [AIRFLOW-4419] Refine concurrency check in scheduler (#5194) |
| - [AIRFLOW-4269] Minor acceleration of jobs._process_task_instances() (#5076) |
| - [AIRFLOW-4341] Remove ``View.render()`` already exists in fab.BaseView (#5125) |
| - [AIRFLOW-4342] Use @cached_property instead of re-implementing it each time (#5126) |
| - [AIRFLOW-4256] Remove noqa from migrations (#5055) |
| - [AIRFLOW-4034] Remove unnecessary string formatting with ``**locals()`` (#4861) |
| - [AIRFLOW-3944] Remove code smells (#4762) |
| |
| Doc-only changes |
| """""""""""""""" |
| - [AIRFLOW-XXX] Add missing doc for annotations param of KubernetesPodOperator (#5666) |
| - [AIRFLOW-XXX] Fix typos in CONTRIBUTING.md (#5626) |
| - [AIRFLOW-XXX] Correct BaseSensorOperator docs (#5562) |
| - [AIRFLOW-4926] Fix example dags where its start_date is datetime.utcnow() (#5553) |
| - [AIRFLOW-4860] Remove Redundant Information in Example Dags (#5497) |
| - [AIRFLOW-4767] Fix errors in the documentation of Dataproc Operator (#5487) |
| - [AIRFLOW-1684] Branching based on XCom variable (Docs) (#4365) |
| - [AIRFLOW-3341] FAQ return DAG object example (#4605) |
| - [AIRFLOW-4433] Add missing type in DockerOperator doc string (#5205) |
| - [AIRFLOW-4321] Replace incorrect info of Max Size limit of GCS Object Size (#5106) |
| - [AIRFLOW-XXX] Add information about user list (#5341) |
| - [AIRFLOW-XXX] Clarify documentation related to autodetect parameter in GCS_to_BQ Op (#5294) |
| - [AIRFLOW-XXX] Remove mention of pytz compatibility from timezone documentation (#5316) |
| - [AIRFLOW-XXX] Add missing docs for GoogleCloudStorageDeleteOperator (#5274) |
| - [AIRFLOW-XXX] Remove incorrect note about Scopes of GCP connection (#5242) |
| - [AIRFLOW-XXX] Fix mistakes in docs of Dataproc operators (#5192) |
| - [AIRFLOW-XXX] Link to correct class for timedelta in macros.rst (#5226) |
| - [AIRFLOW-XXX] Add Kamil as committer (#5216) |
| - [AIRFLOW-XXX] Add Joshua and Kevin as committer (#5207) |
| - [AIRFLOW-XXX] Reduce log spam in tests (#5174) |
| - [AIRFLOW-XXX] Speed up tests for PythonSensor (#5158) |
| - [AIRFLOW-XXX] Add Bas Harenslak to committer list (#5157) |
| - [AIRFLOW-XXX] Add Jarek Potiuk to committer list (#5132) |
| - [AIRFLOW-XXX] Update docstring for SchedulerJob (#5105) |
| - [AIRFLOW-XXX] Fix docstrings for CassandraToGoogleCloudStorageOperator (#5103) |
| - [AIRFLOW-XXX] update SlackWebhookHook and SlackWebhookOperator docstring (#5074) |
| - [AIRFLOW-XXX] Ignore Python files under node_modules in docs (#5063) |
| - [AIRFLOW-XXX] Build a universal wheel with LICNESE files (#5052) |
| - [AIRFLOW-XXX] Fix docstrings of SQSHook (#5099) |
| - [AIRFLOW-XXX] Use Py3.7 on readthedocs |
| - [AIRFLOW-4446] Fix typos (#5217) |
| |
| |
| |
| Airflow 1.10.3, 2019-04-09 |
| -------------------------- |
| |
| New Feature |
| """"""""""" |
| |
| - [AIRFLOW-4232] Add ``none_skipped`` trigger rule (#5032) |
| - [AIRFLOW-3971] Add Google Cloud Natural Language operators (#4980) |
| - [AIRFLOW-4069] Add Opsgenie Alert Hook and Operator (#4903) |
| - [AIRFLOW-3552] Fix encoding issue in ImapAttachmentToS3Operator (#5040) |
| - [AIRFLOW-3552] Add ImapAttachmentToS3Operator (#4476) |
| - [AIRFLOW-1526] Add dingding hook and operator (#4895) |
| - [AIRFLOW-3490] Add BigQueryHook's Ability to Patch Table/View (#4299) |
| - [AIRFLOW-3918] Add SSH private-key support to git-sync for KubernetesExecutor (#4777) |
| - [AIRFLOW-3659] Create Google Cloud Transfer Service Operators (#4792) |
| - [AIRFLOW-3939] Add Google Cloud Translate operator (#4755) |
| - [AIRFLOW-3541] Add Avro logical type conversion to bigquery hook (#4553) |
| - [AIRFLOW-4106] instrument staving tasks in pool (#4927) |
| - [AIRFLOW-2568] Azure Container Instances operator (#4121) |
| - [AIRFLOW-4107] instrument executor (#4928) |
| - [AIRFLOW-4033] record stats of task duration (#4858) |
| - [AIRFLOW-3892] Create Redis pub sub sensor (#4712) |
| - [AIRFLOW-4124] add get_table and get_table_location in aws_glue_hook and tests (#4942) |
| - [AIRFLOW-1262] Adds missing docs for email configuration (#4557) |
| - [AIRFLOW-3701] Add Google Cloud Vision Product Search operators (#4665) |
| - [AIRFLOW-3766] Add support for kubernetes annotations (#4589) |
| - [AIRFLOW-3741] Add extra config to Oracle hook (#4584) |
| - [AIRFLOW-1262] Allow configuration of email alert subject and body (#2338) |
| - [AIRFLOW-2985] Operators for S3 object copying/deleting (#3823) |
| - [AIRFLOW-2993] s3_to_sftp and sftp_to_s3 operators (#3828) |
| - [AIRFLOW-3799] Add compose method to GoogleCloudStorageHook (#4641) |
| - [AIRFLOW-3218] add support for poking a whole DAG (#4058) |
| - [AIRFLOW-3315] Add ImapAttachmentSensor (#4161) |
| - [AIRFLOW-3556] Add cross join set dependency function (#4356) |
| |
| Improvement |
| """"""""""" |
| |
| - [AIRFLOW-3823] Exclude branch's downstream tasks from the tasks to skip (#4666) |
| - [AIRFLOW-3274] Add run_as_user and fs_group options for Kubernetes (#4648) |
| - [AIRFLOW-4247] Template Region on the DataprocOperators (#5046) |
| - [AIRFLOW-4008] Add envFrom for Kubernetes Executor (#4952) |
| - [AIRFLOW-3947] Flash msg for no DAG-level access error (#4767) |
| - [AIRFLOW-3287] Moving database clean-up code into the CoreTest.tearDown() (#4122) |
| - [AIRFLOW-4058] Name models test file to get automatically picked up (#4901) |
| - [AIRFLOW-3830] Remove DagBag from /dag_details (#4831) |
| - [AIRFLOW-3596] Clean up undefined template variables. (#4401) |
| - [AIRFLOW-3573] Remove DagStat table (#4378) |
| - [AIRFLOW-3623] Fix bugs in Download task logs (#5005) |
| - [AIRFLOW-4173] Improve SchedulerJob.process_file() (#4993) |
| - [AIRFLOW-3540] Warn if old airflow.cfg file is found (#5006) |
| - [AIRFLOW-4000] Return response when no file (#4822) |
| - [AIRFLOW-3383] Rotate fernet keys. (#4225) |
| - [AIRFLOW-3003] Pull the krb5 image instead of building (#3844) |
| - [AIRFLOW-3862] Check types with mypy. (#4685) |
| - [AIRFLOW-251] Add option SQL_ALCHEMY_SCHEMA parameter to specify schema for metadata (#4199) |
| - [AIRFLOW-1814] Temple PythonOperator {op_args,op_kwargs} fields (#4691) |
| - [AIRFLOW-3730] Standarization use of logs mechanisms (#4556) |
| - [AIRFLOW-3770] Validation of documentation on CI] (#4593) |
| - [AIRFLOW-3866] Run docker-compose pull silently in CI (#4688) |
| - [AIRFLOW-3685] Move licence header check (#4497) |
| - [AIRFLOW-3670] Add stages to Travis build (#4477) |
| - [AIRFLOW-3937] KubernetesPodOperator support for envFrom configMapRef and secretRef (#4772) |
| - [AIRFLOW-3408] Remove outdated info from Systemd Instructions (#4269) |
| - [AIRFLOW-3202] add missing documentation for AWS hooks/operator (#4048) |
| - [AIRFLOW-3908] Add more Google Cloud Vision operators (#4791) |
| - [AIRFLOW-2915] Add example DAG for GoogleCloudStorageToBigQueryOperator (#3763) |
| - [AIRFLOW-3062] Add Qubole in integration docs (#3946) |
| - [AIRFLOW-3288] Add SNS integration (#4123) |
| - [AIRFLOW-3148] Remove unnecessary arg "parameters" in RedshiftToS3Transfer (#3995) |
| - [AIRFLOW-3049] Add extra operations for Mongo hook (#3890) |
| - [AIRFLOW-3559] Add missing options to DatadogHook. (#4362) |
| - [AIRFLOW-1191] Simplify override of spark submit command. (#4360) |
| - [AIRFLOW-3155] Add ability to filter by a last modified time in GCS Operator (#4008) |
| - [AIRFLOW-2864] Fix docstrings for SubDagOperator (#3712) |
| - [AIRFLOW-4062] Improve docs on install extra package commands (#4966) |
| - [AIRFLOW-3743] Unify different methods of working out AIRFLOW_HOME (#4705) |
| - [AIRFLOW-4002] Option to open debugger on errors in `airflow test`. (#4828) |
| - [AIRFLOW-3997] Extend Variable.get so it can return None when var not found (#4819) |
| - [AIRFLOW-4009] Fix docstring issue in GCSToBQOperator (#4836) |
| - [AIRFLOW-3980] Unify logger (#4804) |
| - [AIRFLOW-4076] Correct port type of beeline_default in init_db (#4908) |
| - [AIRFLOW-4046] Add validations for poke_interval & timeout for Sensor (#4878) |
| - [AIRFLOW-3744] Abandon the use of obsolete aliases of methods (#4568) |
| - [AIRFLOW-3865] Add API endpoint to get Python code of dag by id (#4687) |
| - [AIRFLOW-3516] Support to create k8 worker pods in batches (#4434) |
| - [AIRFLOW-2843] Add flag in ExternalTaskSensor to check if external DAG/task exists (#4547) |
| - [AIRFLOW-2224] Add support CSV files in MySqlToGoogleCloudStorageOperator (#4738) |
| - [AIRFLOW-3895] GoogleCloudStorageHook/Op create_bucket takes optional resource params (#4717) |
| - [AIRFLOW-3950] Improve AirflowSecurityManager.update_admin_perm_view (#4774) |
| - [AIRFLOW-4006] Make better use of Set in AirflowSecurityManager (#4833) |
| - [AIRFLOW-3917] Specify alternate kube config file/context when running out of cluster (#4859) |
| - [AIRFLOW-3911] Change Harvesting DAG parsing results to DEBUG log level (#4729) |
| - [AIRFLOW-3584] Use ORM DAGs for index view. (#4390) |
| - [AIRFLOW-2821] Refine Doc "Plugins" (#3664) |
| - [AIRFLOW-3561] Improve queries (#4368) |
| - [AIRFLOW-3600] Remove dagbag from trigger (#4407) |
| - [AIRFLOW-3713] Updated documentation for GCP optional project_id (#4541) |
| - [AIRFLOW-2767] Upgrade gunicorn to 19.5.0 to avoid moderate-severity CVE (#4795) |
| - [AIRFLOW-3795] provide_context param is now used (#4735) |
| - [AIRFLOW-4012] Upgrade tabulate to 0.8.3 (#4838) |
| - [AIRFLOW-3623] Support download logs by attempts from UI (#4425) |
| - [AIRFLOW-2715] Use region setting when launching Dataflow templates (#4139) |
| - [AIRFLOW-3932] Update unit tests and documentation for safe mode flag. (#4760) |
| - [AIRFLOW-3932] Optionally skip dag discovery heuristic. (#4746) |
| - [AIRFLOW-3258] K8S executor environment variables section. (#4627) |
| - [AIRFLOW-3931] set network, subnetwork when launching dataflow template (#4744) |
| - [AIRFLOW-4095] Add template_fields for S3CopyObjectOperator & S3DeleteObjectsOperator (#4920) |
| - [AIRFLOW-2798] Remove needless code from models.py |
| - [AIRFLOW-3731] Constrain mysqlclient to <1.4 (#4558) |
| - [AIRFLOW-3139] include parameters into log.info in SQL operators, if any (#3986) |
| - [AIRFLOW-3174] Refine Docstring for SQL Operators & Hooks (#4043) |
| - [AIRFLOW-3933] Fix various typos (#4747) |
| - [AIRFLOW-3905] Allow using "parameters" in SqlSensor (#4723) |
| - [AIRFLOW-2761] Parallelize enqueue in celery executor (#4234) |
| - [AIRFLOW-3540] Respect environment config when looking up config file. (#4340) |
| - [AIRFLOW-2156] Parallelize Celery Executor task state fetching (#3830) |
| - [AIRFLOW-3702] Add backfill option to run backwards (#4676) |
| - [AIRFLOW-3821] Add replicas logic to GCP SQL example DAG (#4662) |
| - [AIRFLOW-3547] Fixed Jinja templating in SparkSubmitOperator (#4347) |
| - [AIRFLOW-3647] Add archives config option to SparkSubmitOperator (#4467) |
| - [AIRFLOW-3802] Updated documentation for HiveServer2Hook (#4647) |
| - [AIRFLOW-3817] Corrected task ids returned by BranchPythonOperator to match the dummy operator ids (#4659) |
| - [AIRFLOW-3782] Clarify docs around celery worker_autoscale in default_airflow.cfg (#4609) |
| - [AIRFLOW-1945] Add Autoscale config for Celery workers (#3989) |
| - [AIRFLOW-3590] Change log message of executor exit status (#4616) |
| - [AIRFLOW-3591] Fix start date, end date, duration for rescheduled tasks (#4502) |
| - [AIRFLOW-3709] Validate `allowed_states` for ExternalTaskSensor (#4536) |
| - [AIRFLOW-3522] Add support for sending Slack attachments (#4332) |
| - [AIRFLOW-3569] Add "Trigger DAG" button in DAG page (#4373) |
| - [AIRFLOW-3044] Dataflow operators accept templated job_name param (#3887) |
| - [AIRFLOW-3023] Fix docstring datatypes |
| - [AIRFLOW-2928] Use uuid4 instead of uuid1 (#3779) |
| - [AIRFLOW-2988] Run specifically python2 for dataflow (#3826) |
| - [AIRFLOW-3697] Vendorize nvd3 and slugify (#4513) |
| - [AIRFLOW-3692] Remove ENV variables to avoid GPL (#4506) |
| - [AIRFLOW-3907] Upgrade flask and set cookie security flags. (#4725) |
| - [AIRFLOW-3698] Add documentation for AWS Connection (#4514) |
| - [AIRFLOW-3616][AIRFLOW-1215] Add aliases for schema with underscore (#4523) |
| - [AIRFLOW-3375] Support returning multiple tasks with BranchPythonOperator (#4215) |
| - [AIRFLOW-3742] Fix handling of "fallback" for AirflowConfigParsxer.getint/boolean (#4674) |
| - [AIRFLOW-3742] Respect the `fallback` arg in airflow.configuration.get (#4567) |
| - [AIRFLOW-3789] Fix flake8 3.7 errors. (#4617) |
| - [AIRFLOW-3602] Improve ImapHook handling of retrieving no attachments (#4475) |
| - [AIRFLOW-3631] Update flake8 and fix lint. (#4436) |
| |
| Bug fixes |
| """"""""" |
| |
| - [AIRFLOW-4248] Fix `FileExistsError` makedirs race in file_processor_handler (#5047) |
| - [AIRFLOW-4240] State-changing actions should be POST requests (#5039) |
| - [AIRFLOW-4246] Flask-Oauthlib needs downstream dependencies pinning due to breaking changes (#5045) |
| - [AIRFLOW-3887] Downgrade dagre-d3 to 0.4.18 (#4713) |
| - [AIRFLOW-3419] Fix S3Hook.select_key on Python3 (#4970) |
| - [AIRFLOW-4127] Correct AzureContainerInstanceHook._get_instance_view's return (#4945) |
| - [AIRFLOW-4172] Fix changes for driver class path option in Spark Submit (#4992) |
| - [AIRFLOW-3615] Preserve case of UNIX socket paths in Connections (#4591) |
| - [AIRFLOW-3417] ECSOperator: pass platformVersion only for FARGATE launch type (#4256) |
| - [AIRFLOW-3884] Fixing doc checker, no warnings allowed anymore and fixed the current… (#4702) |
| - [AIRFLOW-2652] implement / enhance baseOperator deepcopy |
| - [AIRFLOW-4001] Update docs about how to run tests (#4826) |
| - [AIRFLOW-3699] Speed up Flake8 (#4515) |
| - [AIRFLOW-4160] Fix redirecting of 'Trigger Dag' Button in DAG Page (#4982) |
| - [AIRFLOW-3650] Skip running on mysql for the flaky test (#4457) |
| - [AIRFLOW-3423] Fix mongo hook to work with anonymous access (#4258) |
| - [AIRFLOW-3982] Fix race condition in CI test (#4968) |
| - [AIRFLOW-3982] Update DagRun state based on its own tasks (#4808) |
| - [AIRFLOW-3737] Kubernetes executor cannot handle long dag/task names (#4636) |
| - [AIRFLOW-3945] Stop inserting row when permission views unchanged (#4764) |
| - [AIRFLOW-4123] Add Exception handling for _change_state method in K8 Executor (#4941) |
| - [AIRFLOW-3771] Minor refactor securityManager (#4594) |
| - [AIRFLOW-987] Pass kerberos cli args keytab and principal to kerberos.run() (#4238) |
| - [AIRFLOW-3736] Allow int value in SqoopOperator.extra_import_options(#4906) |
| - [AIRFLOW-4063] Fix exception string in BigQueryHook [2/2] (#4902) |
| - [AIRFLOW-4063] Fix exception string in BigQueryHook (#4899) |
| - [AIRFLOW-4037] Log response in SimpleHttpOperator even if the response check fails |
| - [AIRFLOW-4044] The documentation of `query_params` in `BigQueryOperator` is wrong. (#4876) |
| - [AIRFLOW-4015] Make missing API endpoints available in classic mode |
| - [AIRFLOW-3153] Send DAG processing stats to statsd (#4748) |
| - [AIRFLOW-2966] Catch ApiException in the Kubernetes Executor (#4209) |
| - [AIRFLOW-4129] Escape HTML in generated tooltips (#4950) |
| - [AIRFLOW-4070] AirflowException -> log.warning for duplicate task dependencies (#4904) |
| - [AIRFLOW-4054] Fix assertEqualIgnoreMultipleSpaces util & add tests (#4886) |
| - [AIRFLOW-3239] Fix test recovery further (#4074) |
| - [AIRFLOW-4053] Fix KubePodOperator Xcom on Kube 1.13.0 (#4883) |
| - [AIRFLOW-2961] Refactor tests.BackfillJobTest.test_backfill_examples test (#3811) |
| - [AIRFLOW-3606] Fix Flake8 test & fix the Flake8 errors introduced since Flake8 test was broken (#4415) |
| - [AIRFLOW-3543] Fix deletion of DAG with rescheduled tasks (#4646) |
| - [AIRFLOW-2548] Output plugin import errors to web UI (#3930) |
| - [AIRFLOW-4019] Fix AWS Athena Sensor object has no attribute 'mode' (#4844) |
| - [AIRFLOW-3758] Fix circular import in WasbTaskHandler (#4601) |
| - [AIRFLOW-3706] Fix tooltip max-width by correcting ordering of CSS files (#4947) |
| - [AIRFLOW-4100] Correctly JSON escape data for tree/graph views (#4921) |
| - [AIRFLOW-3636] Fix a test introduced in #4425 (#4446) |
| - [AIRFLOW-3977] Add examples of trigger rules in doc (#4805) |
| - [AIRFLOW-2511] Fix improper failed session commit handling causing deadlocks (#4769) |
| - [AIRFLOW-3962] Added graceful handling for creation of dag_run of a dag which doesn't have any task (#4781) |
| - [AIRFLOW-3881] Correct to_csv row number (#4699) |
| - [AIRFLOW-3875] Simplify SlackWebhookHook code and change docstring (#4696) |
| - [AIRFLOW-3733] Don't raise NameError in HQL hook to_csv when no rows returned (#4560) |
| - [AIRFLOW-3734] Fix hql not run when partition is None (#4561) |
| - [AIRFLOW-3767] Correct bulk insert function (#4773) |
| - [AIRFLOW-4087] remove sudo in basetaskrunner on_finish (#4916) |
| - [AIRFLOW-3768] Escape search parameter in pagination controls (#4911) |
| - [AIRFLOW-4045] Fix hard-coded URLs in FAB-based UI (#4914) |
| - [AIRFLOW-3123] Use a stack for DAG context management (#3956) |
| - [AIRFLOW-3060] DAG context manager fails to exit properly in certain circumstances |
| - [AIRFLOW-3924] Fix try number in alert emails (#4741) |
| - [AIRFLOW-4083] Add tests for link generation utils (#4912) |
| - [AIRFLOW-2190] Send correct HTTP status for base_url not found (#4910) |
| - [AIRFLOW-4015] Add get_dag_runs GET endpoint to "classic" API (#4884) |
| - [AIRFLOW-3239] Enable existing CI tests (#4131) |
| - [AIRFLOW-1390] Update Alembic to 0.9 (#3935) |
| - [AIRFLOW-3885] Fix race condition in scheduler test (#4737) |
| - [AIRFLOW-3885] ~10x speed-up of SchedulerJobTest suite (#4730) |
| - [AIRFLOW-3780] Fix some incorrect when base_url is used (#4643) |
| - [AIRFLOW-3807] Fix Graph View Highlighting of Tasks (#4653) |
| - [AIRFLOW-3009] Import Hashable from collection.abc to fix Python 3.7 deprecation warning (#3849) |
| - [AIRFLOW-2231] Fix relativedelta DAG schedule_interval (#3174) |
| - [AIRFLOW-2641] Fix MySqlToHiveTransfer to handle MySQL DECIMAL correctly |
| - [AIRFLOW-3751] Option to allow malformed schemas for LDAP authentication (#4574) |
| - [AIRFLOW-2888] Add deprecation path for task_runner config change (#4851) |
| - [AIRFLOW-2930] Fix celery executor scheduler crash (#3784) |
| - [AIRFLOW-2888] Remove shell=True and bash from task launch (#3740) |
| - [AIRFLOW-3885] ~2.5x speed-up for backfill tests (#4731) |
| - [AIRFLOW-3885] ~20x speed-up of slowest unit test (#4726) |
| - [AIRFLOW-2508] Handle non string types in Operators templatized fields (#4292) |
| - [AIRFLOW-3792] Fix validation in BQ for useLegacySQL & queryParameters (#4626) |
| - [AIRFLOW-3749] Fix Edit Dag Run page when using RBAC (#4613) |
| - [AIRFLOW-3801] Fix DagBag collect dags invocation to prevent examples to be loaded (#4677) |
| - [AIRFLOW-3774] Register blueprints with RBAC web app (#4598) |
| - [AIRFLOW-3719] Handle StopIteration in CloudWatch logs retrieval (#4516) |
| - [AIRFLOW-3108] Define get_autocommit method for MsSqlHook (#4525) |
| - [AIRFLOW-3074] Add relevant ECS options to ECS operator. (#3908) |
| - [AIRFLOW-3353] Upgrade Redis client (#4834) |
| - [AIRFLOW-3250] Fix for Redis Hook for not authorised connection calls (#4090) |
| - [AIRFLOW-2009] Fix dataflow hook connection-id (#4563) |
| - [AIRFLOW-2190] Fix TypeError when returning 404 (#4596) |
| - [AIRFLOW-2876] Update Tenacity to 4.12 (#3723) |
| - [AIRFLOW-3923] Update flask-admin dependency to 1.5.3 to resolve security vulnerabilities from safety (#4739) |
| - [AIRFLOW-3683] Fix formatting of error message for invalid TriggerRule (#4490) |
| - [AIRFLOW-2787] Allow is_backfill to handle NULL DagRun.run_id (#3629) |
| - [AIRFLOW-3639] Fix request creation in Jenkins Operator (#4450) |
| - [AIRFLOW-3779] Don't install enum34 backport when not needed (#4620) |
| - [AIRFLOW-3079] Improve migration scripts to support MSSQL Server (#3964) |
| - [AIRFLOW-2735] Use equality, not identity, check for detecting AWS Batch failures[] |
| - [AIRFLOW-2706] AWS Batch Operator should use top-level job state to determine status |
| - [AIRFLOW-XXX] Fix typo in http_operator.py |
| - [AIRFLOW-XXX] Solve lodash security warning (#4820) |
| - [AIRFLOW-XXX] Pin version of tornado pulled in by celery. (#4815) |
| - [AIRFLOW-XXX] Upgrade FAB to 1.12.3 (#4694) |
| - [AIRFLOW-XXX] Pin pinodb dependency (#4704) |
| - [AIRFLOW-XXX] Pin version of Pip in tests to work around pypa/pip#6163 (#4576) |
| - [AIRFLOW-XXX] Fix spark submit hook KeyError (#4578) |
| - [AIRFLOW-XXX] Pin psycopg2 due to breaking change (#5036) |
| - [AIRFLOW-XXX] Pin Sendgrid dep. (#5031) |
| - [AIRFLOW-XXX] Fix flaky test - test_execution_unlimited_parallelism (#4988) |
| |
| Misc/Internal |
| """"""""""""" |
| |
| - [AIRFLOW-4144] Add description of is_delete_operator_pod (#4943) |
| - [AIRFLOW-3476][AIRFLOW-3477] Move Kube classes out of models.py (#4443) |
| - [AIRFLOW-3464] Move SkipMixin out of models.py (#4386) |
| - [AIRFLOW-3463] Move Log out of models.py (#4639) |
| - [AIRFLOW-3458] Move connection tests (#4680) |
| - [AIRFLOW-3461] Move TaskFail out of models.py (#4630) |
| - [AIRFLOW-3462] Move TaskReschedule out of models.py (#4618) |
| - [AIRFLOW-3474] Move SlaMiss out of models.py (#4608) |
| - [AIRFLOW-3475] Move ImportError out of models.py (#4383) |
| - [AIRFLOW-3459] Move DagPickle to separate file (#4374) |
| - [AIRFLOW-3925] Don't pull docker-images on pretest (#4740) |
| - [AIRFLOW-4154] Correct string formatting in jobs.py (#4972) |
| - [AIRFLOW-3458] Deprecation path for moving models.Connection |
| - [AIRFLOW-3458] Move models.Connection into separate file (#4335) |
| - [AIRFLOW-XXX] Remove old/non-test files that nose ignores (#4930) |
| |
| Doc-only changes |
| """""""""""""""" |
| |
| - [AIRFLOW-3996] Add view source link to included fragments |
| - [AIRFLOW-3811] Automatic generation of API Reference in docs (#4788) |
| - [AIRFLOW-3810] Remove duplicate autoclass directive (#4656) |
| - [AIRFLOW-XXX] Mention that statsd must be installed to gather metrics (#5038) |
| - [AIRFLOW-XXX] Add contents to cli (#4825) |
| - [AIRFLOW-XXX] fix check docs failure on CI (#4998) |
| - [AIRFLOW-XXX] Fix syntax docs errors (#4789) |
| - [AIRFLOW-XXX] Docs rendering improvement (#4684) |
| - [AIRFLOW-XXX] Automatically link Jira/GH on doc's changelog page (#4587) |
| - [AIRFLOW-XXX] Mention Oracle in the Extra Packages documentation (#4987) |
| - [AIRFLOW-XXX] Drop deprecated sudo option; use default docker compose on Travis. (#4732) |
| - [AIRFLOW-XXX] Update kubernetes.rst docs (#3875) |
| - [AIRFLOW-XXX] Improvements to formatted content in documentation (#4835) |
| - [AIRFLOW-XXX] Add Daniel to committer list (#4961) |
| - [AIRFLOW-XXX] Add Xiaodong Deng to committers list |
| - [AIRFLOW-XXX] Add history become ASF top level project (#4757) |
| - [AIRFLOW-XXX] Move out the examples from integration.rst (#4672) |
| - [AIRFLOW-XXX] Extract reverse proxy info to a separate file (#4657) |
| - [AIRFLOW-XXX] Reduction of the number of warnings in the documentation (#4585) |
| - [AIRFLOW-XXX] Fix GCS Operator docstrings (#4054) |
| - [AIRFLOW-XXX] Fix Docstrings in Hooks, Sensors & Operators (#4137) |
| - [AIRFLOW-XXX] Split guide for operators to multiple files (#4814) |
| - [AIRFLOW-XXX] Split connection guide to multiple files (#4824) |
| - [AIRFLOW-XXX] Remove almost all warnings from building docs (#4588) |
| - [AIRFLOW-XXX] Add backreference in docs between operator and integration (#4671) |
| - [AIRFLOW-XXX] Improve linking to classes (#4655) |
| - [AIRFLOW-XXX] Mock optional modules when building docs (#4586) |
| - [AIRFLOW-XXX] Update plugin macros documentation (#4971) |
| - [AIRFLOW-XXX] Add missing docstring for 'autodetect' in GCS to BQ Operator (#4979) |
| - [AIRFLOW-XXX] Add missing GCP operators to Docs (#4260) |
| - [AIRFLOW-XXX] Fixing the issue in Documentation (#3756) |
| - [AIRFLOW-XXX] Add Hint at user defined macros (#4885) |
| - [AIRFLOW-XXX] Correct schedule_interval in Scheduler docs (#4157) |
| - [AIRFLOW-XXX] Improve airflow-jira script to make RelManager's life easier (#4857) |
| - [AIRFLOW-XXX] Add missing class references to docs (#4644) |
| - [AIRFLOW-XXX] Fix typo (#4564) |
| - [AIRFLOW-XXX] Add a doc about fab security (#4595) |
| - [AIRFLOW-XXX] Speed up DagBagTest cases (#3974) |
| |
| |
| Airflow 1.10.2, 2019-01-19 |
| -------------------------- |
| |
| New features |
| """""""""""" |
| |
| - [AIRFLOW-2658] Add GCP specific k8s pod operator (#3532) |
| - [AIRFLOW-2440] Google Cloud SQL import/export operator (#4251) |
| - [AIRFLOW-3212] Add AwsGlueCatalogPartitionSensor (#4112) |
| - [AIRFLOW-2750] Add subcommands to delete and list users |
| - [AIRFLOW-3480] Add GCP Spanner Database Operators (#4353) |
| - [AIRFLOW-3560] Add DayOfWeek Sensor (#4363) |
| - [AIRFLOW-3371] BigQueryHook's Ability to Create View (#4213) |
| - [AIRFLOW-3332] Add method to allow inserting rows into BQ table (#4179) |
| - [AIRFLOW-3055] add get_dataset and get_datasets_list to bigquery_hook (#3894) |
| - [AIRFLOW-2887] Added BigQueryCreateEmptyDatasetOperator and create_empty_dataset to bigquery_hook (#3876) |
| - [AIRFLOW-2758] Add a sensor for MongoDB |
| - [AIRFLOW-2640] Add Cassandra table sensor |
| - [AIRFLOW-3398] Google Cloud Spanner instance database query operator (#4314) |
| - [AIRFLOW-3310] Google Cloud Spanner deploy / delete operators (#4286) |
| - [AIRFLOW-3406] Implement an Azure CosmosDB operator (#4265) |
| - [AIRFLOW-3434] Allows creating intermediate dirs in SFTPOperator (#4270) |
| - [AIRFLOW-3345] Add Google Cloud Storage (GCS) operators for ACL (#4192) |
| - [AIRFLOW-3266] Add AWS Athena Hook and Operator (#4111) |
| - [AIRFLOW-3346] Add hook and operator for GCP transfer service (#4189) |
| - [AIRFLOW-2983] Add prev_ds_nodash and next_ds_nodash macro (#3821) |
| - [AIRFLOW-3403] Add AWS Athena Sensor (#4244) |
| - [AIRFLOW-3323] Support HTTP basic authentication for Airflow Flower (#4166) |
| - [AIRFLOW-3410] Add feature to allow Host Key Change for SSH Op (#4249) |
| - [AIRFLOW-3275] Add Google Cloud SQL Query operator (#4170) |
| - [AIRFLOW-2691] Manage JS dependencies via npm |
| - [AIRFLOW-2795] Oracle to Oracle Transfer Operator (#3639) |
| - [AIRFLOW-2596] Add Oracle to Azure Datalake Transfer Operator |
| - [AIRFLOW-3220] Add Instance Group Manager Operators for GCE (#4167) |
| - [AIRFLOW-2882] Add import and export for pool cli using JSON |
| - [AIRFLOW-2965] CLI tool to show the next execution datetime (#3834) |
| - [AIRFLOW-2874] Enables FAB's theme support (#3719) |
| - [AIRFLOW-3336] Add new TriggerRule for 0 upstream failures (#4182) |
| |
| Improvements |
| """""""""""" |
| |
| - [AIRFLOW-3680] Consistency update in tests for All GCP-related operators (#4493) |
| - [AIRFLOW-3675] Use googleapiclient for google apis (#4484) |
| - [AIRFLOW-3205] Support multipart uploads to GCS (#4084) |
| - [AIRFLOW-2826] Add GoogleCloudKMSHook (#3677) |
| - [AIRFLOW-3676] Add required permission to CloudSQL export/import example (#4489) |
| - [AIRFLOW-3679] Added Google Cloud Base Hook to documentation (#4487) |
| - [AIRFLOW-3594] Unify different License Header |
| - [AIRFLOW-3197] Remove invalid parameter KeepJobFlowAliveWhenNoSteps in example DAG (#4404) |
| - [AIRFLOW-3504] Refine the functionality of "/health" endpoint (#4309) |
| - [AIRFLOW-3103][AIRFLOW-3147] Update flask-appbuilder (#3937) |
| - [AIRFLOW-3168] More resilient database use in CI (#4014) |
| - [AIRFLOW-3076] Remove preloading of MySQL testdata (#3911) |
| - [AIRFLOW-3035] Allow custom 'job_error_states' in dataproc ops (#3884) |
| - [AIRFLOW-3246] Make hmsclient optional in airflow.hooks.hive_hooks (#4080) |
| - [AIRFLOW-3059] Log how many rows are read from Postgres (#3905) |
| - [AIRFLOW-2463] Make task instance context available for hive queries |
| - [AIRFLOW-3190] Make flake8 compliant (#4035) |
| - [AIRFLOW-1998] Implemented DatabricksRunNowOperator for jobs/run-now … (#3813) |
| - [AIRFLOW-2267] Airflow DAG level access (#3197) |
| - [AIRFLOW-2359] Add set failed for DagRun and task in tree view (#3255) |
| - [AIRFLOW-3008] Move Kubernetes example DAGs to contrib |
| - [AIRFLOW-3402] Support global k8s affinity and toleration configs (#4247) |
| - [AIRFLOW-3610] Add region param for EMR jobflow creation (#4418) |
| - [AIRFLOW-3531] Fix test for GCS to GCS Transfer Hook (#4452) |
| - [AIRFLOW-3531] Add gcs to gcs transfer operator. (#4331) |
| - [AIRFLOW-3034] Readme updates : Add Slack & Twitter, remove Gitter |
| - [AIRFLOW-3028] Update Text & Images in Readme.md |
| - [AIRFLOW-208] Add badge to show supported Python versions (#3839) |
| - [AIRFLOW-2238] Update PR tool to push directly to GitHub |
| - [AIRFLOW-2238] Flake8 fixes on dev/airflow-pr |
| - [AIRFLOW-2238] Update PR tool to remove outdated info (#3978) |
| - [AIRFLOW-3005] Replace 'Airbnb Airflow' with 'Apache Airflow' (#3845) |
| - [AIRFLOW-3150] Make execution_date templated in TriggerDagRunOperator (#4359) |
| - [AIRFLOW-1196][AIRFLOW-2399] Add templated field in TriggerDagRunOperator (#4228) |
| - [AIRFLOW-3340] Placeholder support in connections form (#4185) |
| - [AIRFLOW-3446] Add Google Cloud BigTable operators (#4354) |
| - [AIRFLOW-1921] Add support for https and user auth (#2879) |
| - [AIRFLOW-2770] Read `dags_in_image` config value as a boolean (#4319) |
| - [AIRFLOW-3022] Add volume mount to KubernetesExecutorConfig (#3855) |
| - [AIRFLOW-2917] Set AIRFLOW__CORE__SQL_ALCHEMY_CONN only when needed (#3766) |
| - [AIRFLOW-2712] Pass annotations to KubernetesExecutorConfig |
| - [AIRFLOW-461] Support autodetected schemas in BigQuery run_load (#3880) |
| - [AIRFLOW-2997] Support cluster fields in bigquery (#3838) |
| - [AIRFLOW-2916] Arg `verify` for AwsHook() & S3 sensors/operators (#3764) |
| - [AIRFLOW-491] Add feature to pass extra api configs to BQ Hook (#3733) |
| - [AIRFLOW-2889] Fix typos detected by github.com/client9/misspell (#3732) |
| - [AIRFLOW-850] Add a PythonSensor (#4349) |
| - [AIRFLOW-2747] Explicit re-schedule of sensors (#3596) |
| - [AIRFLOW-3392] Add index on dag_id in sla_miss table (#4235) |
| - [AIRFLOW-3001] Add index 'ti_dag_date' to taskinstance (#3885) |
| - [AIRFLOW-2861] Add index on log table (#3709) |
| - [AIRFLOW-3518] Performance fixes for topological_sort of Tasks (#4322) |
| - [AIRFLOW-3521] Fetch more than 50 items in `airflow-jira compare` script (#4300) |
| - [AIRFLOW-1919] Add option to query for DAG runs given a DAG ID |
| - [AIRFLOW-3444] Explicitly set transfer operator description. (#4279) |
| - [AIRFLOW-3411] Add OpenFaaS hook (#4267) |
| - [AIRFLOW-2785] Add context manager entry points to mongoHook |
| - [AIRFLOW-2524] Add SageMaker doc to AWS integration section (#4278) |
| - [AIRFLOW-3479] Keeps records in Log Table when DAG is deleted (#4287) |
| - [AIRFLOW-2948] Arg check & better doc - SSHOperator & SFTPOperator (#3793) |
| - [AIRFLOW-2245] Add remote_host of SSH/SFTP operator as templated field (#3765) |
| - [AIRFLOW-2670] Update SSH Operator's Hook to respect timeout (#3666) |
| - [AIRFLOW-3380] Add metrics documentation (#4219) |
| - [AIRFLOW-3361] Log the task_id in the PendingDeprecationWarning from BaseOperator (#4030) |
| - [AIRFLOW-3213] Create ADLS to GCS operator (#4134) |
| - [AIRFLOW-3395] added the REST API endpoints to the doc (#4236) |
| - [AIRFLOW-3294] Update connections form and integration docs (#4129) |
| - [AIRFLOW-3236] Create AzureDataLakeStorageListOperator (#4094) |
| - [AIRFLOW-3062] Add Qubole in integration docs (#3946) |
| - [AIRFLOW-3306] Disable flask-sqlalchemy modification tracking. (#4146) |
| - [AIRFLOW-2867] Refactor Code to conform standards (#3714) |
| - [AIRFLOW-2753] Add dataproc_job_id instance var holding actual DP jobId |
| - [AIRFLOW-3132] Enable specifying auto_remove option for DockerOperator (#3977) |
| - [AIRFLOW-2731] Raise psutil restriction to <6.0.0 |
| - [AIRFLOW-3384] Allow higher versions of Sqlalchemy and Jinja2 (#4227) |
| - [Airflow-2760] Decouple DAG parsing loop from scheduler loop (#3873) |
| - [AIRFLOW-3004] Add config disabling scheduler cron (#3899) |
| - [AIRFLOW-3175] Fix docstring format in airflow/jobs.py (#4025) |
| - [AIRFLOW-3589] Visualize reschedule state in all views (#4408) |
| - [AIRFLOW-2698] Simplify Kerberos code (#3563) |
| - [AIRFLOW-2499] Dockerise CI pipeline (#3393) |
| - [AIRFLOW-3432] Add test for feature "Delete DAG in UI" (#4266) |
| - [AIRFLOW-3301] Update DockerOperator CI test for PR #3977 (#4138) |
| - [AIRFLOW-3478] Make sure that the session is closed |
| - [AIRFLOW-3687] Add missing @apply_defaults decorators (#4498) |
| - [AIRFLOW-3691] Update notice to 2019 (#4503) |
| - [AIRFLOW-3689] Update pop-up message when deleting DAG in RBAC UI (#4505) |
| - [AIRFLOW-2801] Skip test_mark_success_no_kill in PostgreSQL on CI (#3642) |
| - [AIRFLOW-3693] Replace psycopg2-binary by psycopg2 (#4508) |
| - [AIRFLOW-3700] Change the lowest allowed version of "requests" (#4517) |
| - [AIRFLOW-3704] Support SSL Protection When Redis is Used as Broker for CeleryExecutor (#4521) |
| - [AIRFLOW-3681] All GCP operators have now optional GCP Project ID (#4500) |
| - [Airflow 2782] Upgrades Dagre D3 version to latest possible |
| - [Airflow 2783] Implement eslint for JS code check (#3641) |
| - [AIRFLOW-2805] Display multiple timezones on UI (#3687) |
| - [AIRFLOW-3302] Small CSS fixes (#4140) |
| - [Airflow-2766] Respect shared datetime across tabs |
| - [AIRFLOW-2776] Compress tree view JSON |
| - [AIRFLOW-2407] Use feature detection for reload() (#3298) |
| - [AIRFLOW-3452] Removed an unused/dangerous display-none (#4295) |
| - [AIRFLOW-3348] Update run statistics on dag refresh (#4197) |
| - [AIRFLOW-3125] Monitor Task Instances creation rates (#3966) |
| |
| |
| Bug fixes |
| """"""""" |
| |
| - [AIRFLOW-3191] Fix not being able to specify execution_date when creating dagrun (#4037) |
| - [AIRFLOW-3657] Fix zendesk integration (#4466) |
| - [AIRFLOW-3605] Load plugins from entry_points (#4412) |
| - [AIRFLOW-3646] Rename plugins_manager.py to test_xx to trigger tests (#4464) |
| - [AIRFLOW-3655] Escape links generated in model views (#4463) |
| - [AIRFLOW-3662] Add dependency for Enum (#4468) |
| - [AIRFLOW-3630] Cleanup of GCP Cloud SQL Connection (#4451) |
| - [AIRFLOW-1837] Respect task start_date when different from dag's (#4010) |
| - [AIRFLOW-2829] Brush up the CI script for minikube |
| - [AIRFLOW-3519] Fix example http operator (#4455) |
| - [AIRFLOW-2811] Fix scheduler_ops_metrics.py to work (#3653) |
| - [AIRFLOW-2751] add job properties update in hive to druid operator. |
| - [AIRFLOW-2918] Remove unused imports |
| - [AIRFLOW-2918] Fix Flake8 violations (#3931) |
| - [AIRFLOW-2771] Add except type to broad S3Hook try catch clauses |
| - [AIRFLOW-2918] Fix Flake8 violations (#3772) |
| - [AIRFLOW-2099] Handle getsource() calls gracefully |
| - [AIRFLOW-3397] Fix integrity error in rbac AirflowSecurityManager (#4305) |
| - [AIRFLOW-3281] Fix Kubernetes operator with git-sync (#3770) |
| - [AIRFLOW-2615] Limit DAGs parsing to once only |
| - [AIRFLOW-2952] Fix Kubernetes CI (#3922) |
| - [AIRFLOW-2933] Enable Codecov on Docker-CI Build (#3780) |
| - [AIRFLOW-2082] Resolve a bug in adding password_auth to api as auth method (#4343) |
| - [AIRFLOW-3612] Remove incubation/incubator mention (#4419) |
| - [AIRFLOW-3581] Fix next_ds/prev_ds semantics for manual runs (#4385) |
| - [AIRFLOW-3527] Update Cloud SQL Proxy to have shorter path for UNIX socket (#4350) |
| - [AIRFLOW-3316] For gcs_to_bq: add missing init of schema_fields var (#4430) |
| - [AIRFLOW-3583] Fix AirflowException import (#4389) |
| - [AIRFLOW-3578] Fix Type Error for BigQueryOperator (#4384) |
| - [AIRFLOW-2755] Added `kubernetes.worker_dags_folder` configuration (#3612) |
| - [AIRFLOW-2655] Fix inconsistency of default config of kubernetes worker |
| - [AIRFLOW-2645][AIRFLOW-2617] Add worker_container_image_pull_policy |
| - [AIRFLOW-2661] fix config dags_volume_subpath and logs_volume_subpath |
| - [AIRFLOW-3550] Standardize GKE hook (#4364) |
| - [AIRFLOW-2863] Fix GKEClusterHook catching wrong exception (#3711) |
| - [AIRFLOW-2939][AIRFLOW-3568] Fix TypeError in GCSToS3Op & S3ToGCSOp (#4371) |
| - [AIRFLOW-3327] Add support for location in BigQueryHook (#4324) |
| - [AIRFLOW-3438] Fix default values in BigQuery Hook & BigQueryOperator (… |
| - [AIRFLOW-3355] Fix BigQueryCursor.execute to work with Python3 (#4198) |
| - [AIRFLOW-3447] Add 2 options for ts_nodash Macro (#4323) |
| - [AIRFLOW-1552] Airflow Filter_by_owner not working with password_auth (#4276) |
| - [AIRFLOW-3484] Fix Over-logging in the k8s executor (#4296) |
| - [AIRFLOW-3309] Add MongoDB connection (#4154) |
| - [AIRFLOW-3414] Fix reload_module in DagFileProcessorAgent (#4253) |
| - [AIRFLOW-1252] API accept JSON when invoking a trigger dag (#2334) |
| - [AIRFLOW-3425] Fix setting default scope in hook (#4261) |
| - [AIRFLOW-3416] Fixes Python 3 compatibility with CloudSqlQueryOperator (#4254) |
| - [AIRFLOW-3263] Ignore exception when 'run' kills already killed job (#4108) |
| - [AIRFLOW-3264] URL decoding when parsing URI for connection (#4109) |
| - [AIRFLOW-3365][AIRFLOW-3366] Allow celery_broker_transport_options to be set with environment variables (#4211) |
| - [AIRFLOW-2642] fix wrong value git-sync initcontainer env GIT_SYNC_ROOT (#3519) |
| - [AIRFLOW-3353] Pin redis version (#4195) |
| - [AIRFLOW-3251] KubernetesPodOperator now uses 'image_pull_secrets' argument when creating Pods (#4188) |
| - [AIRFLOW-2705] Move class-level moto decorator to method-level |
| - [AIRFLOW-3233] Fix deletion of DAGs in the UI (#4069) |
| - [AIRFLOW-2908] Allow retries with KubernetesExecutor. (#3758) |
| - [AIRFLOW-1561] Fix scheduler to pick up example DAGs without other DAGs (#2635) |
| - [AIRFLOW-3352] Fix expose_config not honoured on RBAC UI (#4194) |
| - [AIRFLOW-3592] Fix logs when task is in rescheduled state (#4492) |
| - [AIRFLOW-3634] Fix GCP Spanner Test (#4440) |
| - [AIRFLOW-XXX] Fix PythonVirtualenvOperator tests (#3968) |
| - [AIRFLOW-3239] Fix/refine tests for api/common/experimental/ (#4255) |
| - [AIRFLOW-2951] Update dag_run table end_date when state change (#3798) |
| - [AIRFLOW-2756] Fix bug in set DAG run state workflow (#3606) |
| - [AIRFLOW-3690] Fix bug to set state of a task for manually-triggered DAGs (#4504) |
| - [AIRFLOW-3319] KubernetsExecutor: Need in try_number in labels if getting them later (#4163) |
| - [AIRFLOW-3724] Fix the broken refresh button on Graph View in RBAC UI |
| - [AIRFLOW-3732] Fix issue when trying to edit connection in RBAC UI |
| - [AIRFLOW-2866] Fix missing CSRF token head when using RBAC UI (#3804) |
| - [AIRFLOW-3259] Fix internal server error when displaying charts (#4114) |
| - [AIRFLOW-3271] Fix issue with persistence of RBAC Permissions modified via UI (#4118) |
| - [AIRFLOW-3141] Handle duration View for missing dag (#3984) |
| - [AIRFLOW-2766] Respect shared datetime across tabs |
| - [AIRFLOW-1413] Fix FTPSensor failing on error message with unexpected (#2450) |
| - [AIRFLOW-3378] KubernetesPodOperator does not delete on timeout failure (#4218) |
| - [AIRFLOW-3245] Fix list processing in resolve_template_files (#4086) |
| - [AIRFLOW-2703] Catch transient DB exceptions from scheduler's heartbeat it does not crash (#3650) |
| - [AIRFLOW-1298] Clear UPSTREAM_FAILED using the clean cli (#3886) |
| |
| Doc-only changes |
| """""""""""""""" |
| |
| - [AIRFLOW-XXX] GCP operators documentation clarifications (#4273) |
| - [AIRFLOW-XXX] Docs: Fix paths to GCS transfer operator (#4479) |
| - [AIRFLOW-XXX] Add missing GCP operators to Docs (#4260) |
| - [AIRFLOW-XXX] Fix Docstrings for Operators (#3820) |
| - [AIRFLOW-XXX] Fix inconsistent comment in example_python_operator.py (#4337) |
| - [AIRFLOW-XXX] Fix incorrect parameter in SFTPOperator example (#4344) |
| - [AIRFLOW-XXX] Add missing remote logging field (#4333) |
| - [AIRFLOW-XXX] Revise template variables documentation (#4172) |
| - [AIRFLOW-XXX] Fix typo in docstring of gcs_to_bq (#3833) |
| - [AIRFLOW-XXX] Fix display of SageMaker operators/hook docs (#4263) |
| - [AIRFLOW-XXX] Better instructions for Airflow flower (#4214) |
| - [AIRFLOW-XXX] Make pip install commands consistent (#3752) |
| - [AIRFLOW-XXX] Add `BigQueryGetDataOperator` to Integration Docs (#4063) |
| - [AIRFLOW-XXX] Don't spam test logs with "bad cron expression" messages (#3973) |
| - [AIRFLOW-XXX] Update committer list based on latest TLP discussion (#4427) |
| - [AIRFLOW-XXX] Fix incorrect statement in contributing guide (#4104) |
| - [AIRFLOW-XXX] Fix Broken Link in CONTRIBUTING.md |
| - [AIRFLOW-XXX] Update Contributing Guide - Git Hooks (#4120) |
| - [AIRFLOW-3426] Correct Python Version Documentation Reference (#4259) |
| - [AIRFLOW-2663] Add instructions to install SSH dependencies |
| - [AIRFLOW-XXX] Clean up installation extra packages table (#3750) |
| - [AIRFLOW-XXX] Remove redundant space in Kerberos (#3866) |
| - [AIRFLOW-3086] Add extras group for google auth to setup.py (#3917) |
| - [AIRFLOW-XXX] Add Kubernetes Dependency in Extra Packages Doc (#4281) |
| - [AIRFLOW-3696] Add Version info to Airflow Documentation (#4512) |
| - [AIRFLOW-XXX] Correct Typo in sensor's exception (#4545) |
| - [AIRFLOW-XXX] Fix a typo of config (#4544) |
| - [AIRFLOW-XXX] Fix BashOperator Docstring (#4052) |
| - [AIRFLOW-3018] Fix Minor issues in Documentation |
| - [AIRFLOW-XXX] Fix Minor issues with Azure Cosmos Operator (#4289) |
| - [AIRFLOW-3382] Fix incorrect docstring in DatastoreHook (#4222) |
| - [AIRFLOW-XXX] Fix copy&paste mistake (#4212) |
| - [AIRFLOW-3260] Correct misleading BigQuery error (#4098) |
| - [AIRFLOW-XXX] Fix Typo in SFTPOperator docstring (#4016) |
| - [AIRFLOW-XXX] Fixing the issue in Documentation (#3998) |
| - [AIRFLOW-XXX] Fix undocumented params in S3_hook |
| - [AIRFLOW-XXX] Fix SlackWebhookOperator execute method comment (#3963) |
| - [AIRFLOW-3070] Refine web UI authentication-related docs (#3863) |
| |
| Airflow 1.10.1, 2018-11-13 |
| -------------------------- |
| |
| New features |
| """""""""""" |
| |
| - [AIRFLOW-2524] Airflow integration with AWS Sagemaker |
| - [AIRFLOW-2657] Add ability to delete DAG from web ui |
| - [AIRFLOW-2780] Adds IMAP Hook to interact with a mail server |
| - [AIRFLOW-2794] Add delete support for Azure blob |
| - [AIRFLOW-2912] Add operators for Google Cloud Functions |
| - [AIRFLOW-2974] Add Start/Restart/Terminate methods Databricks Hook |
| - [AIRFLOW-2989] No Parameter to change bootDiskType for DataprocClusterCreateOperator |
| - [AIRFLOW-3078] Basic operators for Google Compute Engine |
| - [AIRFLOW-3147] Update Flask-AppBuilder version |
| - [AIRFLOW-3231] Basic operators for Google Cloud SQL (deploy / patch / delete) |
| - [AIRFLOW-3276] Google Cloud SQL database create / patch / delete operators |
| |
| Improvements |
| """""""""""" |
| |
| - [AIRFLOW-393] Add progress callbacks for FTP downloads |
| - [AIRFLOW-520] Show Airflow version on web page |
| - [AIRFLOW-843] Exceptions now available in context during on_failure_callback |
| - [AIRFLOW-2476] Update tabulate dependency to v0.8.2 |
| - [AIRFLOW-2592] Bump Bleach dependency |
| - [AIRFLOW-2622] Add "confirm=False" option to SFTPOperator |
| - [AIRFLOW-2662] support affinity & nodeSelector policies for kubernetes executor/operator |
| - [AIRFLOW-2709] Improve error handling in Databricks hook |
| - [AIRFLOW-2723] Update lxml dependency to >= 4.0. |
| - [AIRFLOW-2763] No precheck mechanism in place during worker initialisation for the connection to metadata database |
| - [AIRFLOW-2789] Add ability to create single node cluster to DataprocClusterCreateOperator |
| - [AIRFLOW-2797] Add ability to create Google Dataproc cluster with custom image |
| - [AIRFLOW-2854] kubernetes_pod_operator add more configuration items |
| - [AIRFLOW-2855] Need to Check Validity of Cron Expression When Process DAG File/Zip File |
| - [AIRFLOW-2904] Clean an unnecessary line in airflow/executors/celery_executor.py |
| - [AIRFLOW-2921] A trivial incorrectness in CeleryExecutor() |
| - [AIRFLOW-2922] Potential deal-lock bug in CeleryExecutor() |
| - [AIRFLOW-2932] GoogleCloudStorageHook - allow compression of file |
| - [AIRFLOW-2949] Syntax Highlight for Single Quote |
| - [AIRFLOW-2951] dag_run end_date Null after a dag is finished |
| - [AIRFLOW-2956] Kubernetes tolerations for pod operator |
| - [AIRFLOW-2997] Support for clustered tables in Bigquery hooks/operators |
| - [AIRFLOW-3006] Fix error when schedule_interval="None" |
| - [AIRFLOW-3008] Move Kubernetes related example DAGs to contrib/example_dags |
| - [AIRFLOW-3025] Allow to specify dns and dns-search parameters for DockerOperator |
| - [AIRFLOW-3067] (www_rbac) Flask flash messages are not displayed properly (no background color) |
| - [AIRFLOW-3069] Decode output of S3 file transform operator |
| - [AIRFLOW-3072] Assign permission get_logs_with_metadata to viewer role |
| - [AIRFLOW-3090] INFO logs are too verbose |
| - [AIRFLOW-3103] Update flask-login |
| - [AIRFLOW-3112] Align SFTP hook with SSH hook |
| - [AIRFLOW-3119] Enable loglevel on celery worker and inherit from airflow.cfg |
| - [AIRFLOW-3137] Make ProxyFix middleware optional |
| - [AIRFLOW-3173] Add _cmd options for more password config options |
| - [AIRFLOW-3177] Change scheduler_heartbeat metric from gauge to counter |
| - [AIRFLOW-3193] Pin docker requirement version to v3 |
| - [AIRFLOW-3195] Druid Hook: Log ingestion spec and task id |
| - [AIRFLOW-3197] EMR Hook is missing some parameters to valid on the AWS API |
| - [AIRFLOW-3232] Make documentation for GCF Functions operator more readable |
| - [AIRFLOW-3262] Can't get log containing Response when using SimpleHttpOperator |
| - [AIRFLOW-3265] Add support for "unix_socket" in connection extra for Mysql Hook |
| |
| Doc-only changes |
| """""""""""""""" |
| |
| - [AIRFLOW-1441] Tutorial Inconsistencies Between Example Pipeline Definition and Recap |
| - [AIRFLOW-2682] Add how-to guide(s) for how to use basic operators like BashOperator and PythonOperator |
| - [AIRFLOW-3104] .airflowignore feature is not mentioned at all in documentation |
| - [AIRFLOW-3237] Refactor example DAGs |
| - [AIRFLOW-3187] Update Airflow.gif file with a slower version |
| - [AIRFLOW-3159] Update Airflow documentation on GCP Logging |
| - [AIRFLOW-3030] Command Line docs incorrect subdir |
| - [AIRFLOW-2990] Docstrings for Hooks/Operators are in incorrect format |
| - [AIRFLOW-3127] Celery SSL Documentation is out-dated |
| - [AIRFLOW-2779] Add license headers to doc files |
| - [AIRFLOW-2779] Add project version to license |
| |
| Bug fixes |
| """"""""" |
| |
| - [AIRFLOW-839] docker_operator.py attempts to log status key without first checking existence |
| - [AIRFLOW-1104] Concurrency check in scheduler should count queued tasks as well as running |
| - [AIRFLOW-1163] Add support for x-forwarded-* headers to support access behind AWS ELB |
| - [AIRFLOW-1195] Cleared tasks in SubDagOperator do not trigger Parent dag_runs |
| - [AIRFLOW-1508] Skipped state not part of State.task_states |
| - [AIRFLOW-1762] Use key_file in SSHHook.create_tunnel() |
| - [AIRFLOW-1837] Differing start_dates on tasks not respected by scheduler. |
| - [AIRFLOW-1874] Support standard SQL in Check, ValueCheck and IntervalCheck BigQuery operators |
| - [AIRFLOW-1917] print() from Python operators end up with extra new line |
| - [AIRFLOW-1970] Database cannot be initialized if an invalid fernet key is provided |
| - [AIRFLOW-2145] Deadlock after clearing a running task |
| - [AIRFLOW-2216] Cannot specify a profile for AWS Hook to load with s3 config file |
| - [AIRFLOW-2574] initdb fails when mysql password contains percent sign |
| - [AIRFLOW-2707] Error accessing log files from web UI |
| - [AIRFLOW-2716] Replace new Python 3.7 keywords |
| - [AIRFLOW-2744] RBAC app doesn't integrate plugins (blueprints etc) |
| - [AIRFLOW-2772] BigQuery hook does not allow specifying both the partition field name and table name at the same time |
| - [AIRFLOW-2778] Bad Import in collect_dag in DagBag |
| - [AIRFLOW-2786] Variables view fails to render if a variable has an empty key |
| - [AIRFLOW-2799] Filtering UI objects by datetime is broken |
| - [AIRFLOW-2800] Remove airflow/ low-hanging linting errors |
| - [AIRFLOW-2825] S3ToHiveTransfer operator may not may able to handle GZIP file with uppercase ext in S3 |
| - [AIRFLOW-2848] dag_id is missing in metadata table "job" for LocalTaskJob |
| - [AIRFLOW-2860] DruidHook: time variable is not updated correctly when checking for timeout |
| - [AIRFLOW-2865] Race condition between on_success_callback and LocalTaskJob's cleanup |
| - [AIRFLOW-2893] Stuck dataflow job due to jobName mismatch. |
| - [AIRFLOW-2895] Prevent scheduler from spamming heartbeats/logs |
| - [AIRFLOW-2900] Code not visible for Packaged DAGs |
| - [AIRFLOW-2905] Switch to regional dataflow job service. |
| - [AIRFLOW-2907] Sendgrid - Attachments - ERROR - Object of type 'bytes' is not JSON serializable |
| - [AIRFLOW-2938] Invalid 'extra' field in connection can raise an AttributeError when attempting to edit |
| - [AIRFLOW-2979] Deprecated Celery Option not in Options list |
| - [AIRFLOW-2981] TypeError in dataflow operators when using GCS jar or py_file |
| - [AIRFLOW-2984] Cannot convert naive_datetime when task has a naive start_date/end_date |
| - [AIRFLOW-2994] flatten_results in BigQueryOperator/BigQueryHook should default to None |
| - [AIRFLOW-3002] ValueError in dataflow operators when using GCS jar or py_file |
| - [AIRFLOW-3012] Email on sla miss is send only to first address on the list |
| - [AIRFLOW-3046] ECS Operator mistakenly reports success when task is killed due to EC2 host termination |
| - [AIRFLOW-3064] No output from `airflow test` due to default logging config |
| - [AIRFLOW-3072] Only admin can view logs in RBAC UI |
| - [AIRFLOW-3079] Improve initdb to support MSSQL Server |
| - [AIRFLOW-3089] Google auth doesn't work under http |
| - [AIRFLOW-3099] Errors raised when some blocks are missing in airflow.cfg |
| - [AIRFLOW-3109] Default user permission should contain 'can_clear' |
| - [AIRFLOW-3111] Confusing comments and instructions for log templates in UPDATING.md and default_airflow.cfg |
| - [AIRFLOW-3124] Broken webserver debug mode (RBAC) |
| - [AIRFLOW-3136] Scheduler Failing the Task retries run while processing Executor Events |
| - [AIRFLOW-3138] Migration cc1e65623dc7 creates issues with postgres |
| - [AIRFLOW-3161] Log Url link does not link to task instance logs in RBAC UI |
| - [AIRFLOW-3162] HttpHook fails to parse URL when port is specified |
| - [AIRFLOW-3183] Potential Bug in utils/dag_processing/DagFileProcessorManager.max_runs_reached() |
| - [AIRFLOW-3203] Bugs in DockerOperator & Some operator test scripts were named incorrectly |
| - [AIRFLOW-3238] Dags, removed from the filesystem, are not deactivated on initdb |
| - [AIRFLOW-3268] Cannot pass SSL dictionary to mysql connection via URL |
| - [AIRFLOW-3277] Invalid timezone transition handling for cron schedules |
| - [AIRFLOW-3295] Require encryption in DaskExecutor when certificates are configured. |
| - [AIRFLOW-3297] EmrStepSensor marks cancelled step as successful |
| |
| Airflow 1.10.0, 2018-08-03 |
| -------------------------- |
| - [AIRFLOW-2870] Use abstract TaskInstance for migration |
| - [AIRFLOW-2859] Implement own UtcDateTime (#3708) |
| - [AIRFLOW-2140] Don't require kubernetes for the SparkSubmit hook |
| - [AIRFLOW-2869] Remove smart quote from default config |
| - [AIRFLOW-2857] Fix Read the Docs env |
| - [AIRFLOW-2817] Force explicit choice on GPL dependency |
| - [AIRFLOW-2716] Replace async and await py3.7 keywords |
| - [AIRFLOW-2810] Fix typo in Xcom model timestamp |
| - [AIRFLOW-2710] Clarify fernet key value in documentation |
| - [AIRFLOW-2606] Fix DB schema and SQLAlchemy model |
| - [AIRFLOW-2646] Fix setup.py not to install snakebite on Python3 |
| - [AIRFLOW-2604] Add index to task_fail |
| - [AIRFLOW-2650] Mark SchedulerJob as succeed when hitting Ctrl-c |
| - [AIRFLOW-2678] Fix db schema unit test to remove checking fab models |
| - [AIRFLOW-2624] Fix webserver login as anonymous |
| - [AIRFLOW-2654] Fix incorrect URL on refresh in Graph View of FAB UI |
| - [AIRFLOW-2668] Handle missing optional cryptography dependency |
| - [AIRFLOW-2681] Include last dag run of externally triggered DAGs in UI. |
| - [AIRFLOW-1840] Support back-compat on old celery config |
| - [AIRFLOW-2612][AIRFLOW-2534] Clean up Hive-related tests |
| - [AIRFLOW-2608] Implements/Standardize custom exceptions for experimental APIs |
| - [AIRFLOW-2607] Fix failing TestLocalClient |
| - [AIRFLOW-2638] dbapi_hook: support REPLACE INTO |
| - [AIRFLOW-2542][AIRFLOW-1790] Rename AWS Batch Operator queue to job_queue |
| - [AIRFLOW-2567] Extract result from the kubernetes pod as Xcom |
| - [AIRFLOW-XXX] Adding REA Group to readme |
| - [AIRFLOW-2601] Allow user to specify k8s config |
| - [AIRFLOW-2559] Azure Fileshare hook |
| - [AIRFLOW-1786] Enforce correct behavior for soft-fail sensors |
| - [AIRFLOW-2355] Airflow trigger tag parameters in subdag |
| - [AIRFLOW-2613] Fix Airflow searching .zip bug |
| - [AIRFLOW-2627] Add a sensor for Cassandra |
| - [AIRFLOW-2634][AIRFLOW-2534] Remove dependency for impyla |
| - [AIRFLOW-2611] Fix wrong dag volume mount path for kubernetes executor |
| - [AIRFLOW-2562] Add Google Kubernetes Engine Operators |
| - [AIRFLOW-2630] Fix classname in test_sql_sensor.py |
| - [AIRFLOW-2534] Fix bug in HiveServer2Hook |
| - [AIRFLOW-2586] Stop getting AIRFLOW_HOME value from config file in bash operator |
| - [AIRFLOW-2605] Fix autocommit for MySqlHook |
| - [AIRFLOW-2539][AIRFLOW-2359] Move remaining log config to configuration file |
| - [AIRFLOW-1656] Tree view dags query changed |
| - [AIRFLOW-2617] add imagePullPolicy config for kubernetes executor |
| - [AIRFLOW-2429] Fix security/task/sensors/ti_deps folders flake8 error |
| - [AIRFLOW-2550] Implements API endpoint to list DAG runs |
| - [AIRFLOW-2512][AIRFLOW-2522] Use google-auth instead of oauth2client |
| - [AIRFLOW-2429] Fix operators folder flake8 error |
| - [AIRFLOW-2585] Fix several bugs in CassandraHook and CassandraToGCSOperator |
| - [AIRFLOW-2597] Restore original dbapi.run() behavior |
| - [AIRFLOW-2590] Fix commit in DbApiHook.run() for no-autocommit DB |
| - [AIRFLOW-1115] fix github oauth api URL |
| - [AIRFLOW-2587] Add TIMESTAMP type mapping to MySqlToHiveTransfer |
| - [AIRFLOW-2591][AIRFLOW-2581] Set default value of autocommit to False in DbApiHook.run() |
| - [AIRFLOW-59] Implement bulk_dump and bulk_load for the Postgres hook |
| - [AIRFLOW-2533] Fix path to DAG's on kubernetes executor workers |
| - [AIRFLOW-2581] RFLOW-2581] Fix DbApiHook autocommit |
| - [AIRFLOW-2578] Add option to use proxies in JiraHook |
| - [AIRFLOW-2575] Make gcs to gcs operator work with large files |
| - [AIRFLOW-437] Send TI context in kill zombies |
| - [AIRFLOW-2566] Change backfill to rerun failed tasks |
| - [AIRFLOW-1021] Fix double login for new users with LDAP |
| - [AIRFLOW-XXX] Typo fix |
| - [AIRFLOW-2561] Fix typo in EmailOperator |
| - [AIRFLOW-2573] Cast BigQuery TIMESTAMP field to float |
| - [AIRFLOW-2560] Adding support for internalIpOnly to DataprocClusterCreateOperator |
| - [AIRFLOW-2565] templatize cluster_label |
| - [AIRFLOW-83] add mongo hook and operator |
| - [AIRFLOW-2558] Clear task/dag is clearing all executions |
| - [AIRFLOW-XXX] Fix doc typos |
| - [AIRFLOW-2513] Change `bql` to `sql` for BigQuery Hooks & Ops |
| - [AIRFLOW-2557] Fix pagination for s3 |
| - [AIRFLOW-2545] Eliminate DeprecationWarning |
| - [AIRFLOW-2500] Fix MySqlToHiveTransfer to transfer unsigned type properly |
| - [AIRFLOW-2462] Change PasswordUser setter to correct syntax |
| - [AIRFLOW-2525] Fix a bug introduced by commit ``dabf1b9`` |
| - [AIRFLOW-2553] Add webserver.pid to .gitignore |
| - [AIRFLOW-1863][AIRFLOW-2529] Add dag run selection widgets to gantt view |
| - [AIRFLOW-2504] Log username correctly and add extra to search columns |
| - [AIRFLOW-2551] Encode binary data with base64 standard rather than base64 url |
| - [AIRFLOW-2537] Add reset-dagrun option to backfill command |
| - [AIRFLOW-2526] dag_run.conf can override params |
| - [AIRFLOW-2544][AIRFLOW-1967] Guard against next major release of Celery, Flower |
| - [AIRFLOW-XXX] Add Yieldr to who is using airflow |
| - [AIRFLOW-2547] Describe how to run tests using Docker |
| - [AIRFLOW-2538] Update faq doc on how to reduce Airflow scheduler latency |
| - [AIRFLOW-2529] Improve graph view performance and usability |
| - [AIRFLOW-2517] backfill support passing key values through CLI |
| - [AIRFLOW-2532] Support logs_volume_subpath for KubernetesExecutor |
| - [AIRFLOW-2466] consider task_id in _change_state_for_tis_without_dagrun |
| - [AIRFLOW-2519] Fix CeleryExecutor with SQLAlchemy |
| - [AIRFLOW-2402] Fix RBAC task log |
| - [AIRFLOW-XXX] Add M4U to user list |
| - [AIRFLOW-2536] docs about how to deal with Airflow initdb failure |
| - [AIRFLOW-2530] KubernetesOperator supports multiple clusters |
| - [AIRFLOW-1499] Eliminate duplicate and unneeded code |
| - [AIRFLOW-2521] backfill - make variable name and logging messages more accurate |
| - [AIRFLOW-2429] Fix hook, macros folder flake8 error |
| - [Airflow-XXX] add Prime to company list |
| - [AIRFLOW-2525] Fix PostgresHook.copy_expert to work with "COPY FROM" |
| - [AIRFLOW-2515] Add dependency on thrift_sasl to hive extra |
| - [AIRFLOW-2523] Add how-to for managing GCP connections |
| - [AIRFLOW-2510] Introduce new macros: prev_ds and next_ds |
| - [AIRFLOW-1730] Unpickle value of XCom queried from DB |
| - [AIRFLOW-2518] Fix broken ToC links in integration.rst |
| - [AIRFLOW-1472] Fix SLA misses triggering on skipped tasks. |
| - [AIRFLOW-2520] CLI - make backfill less verbose |
| - [AIRFLOW-2107] add time_partitioning to run_query on BigQueryBaseCursor |
| - [AIRFLOW-1057][AIRFLOW-1380][AIRFLOW-2362][2362] AIRFLOW Update DockerOperator to new API |
| - [AIRFLOW-2415] Make Airflow DAG templating render numbers |
| - [AIRFLOW-2473] Fix wrong skip condition for TransferTests |
| - [AIRFLOW-2472] Implement MySqlHook.bulk_dump |
| - [AIRFLOW-2419] Use default view for subdag operator |
| - [AIRFLOW-2498] Fix Unexpected argument in SFTP Sensor |
| - [AIRFLOW-2509] Separate config docs into how-to guides |
| - [AIRFLOW-2429] Add BaseExecutor back |
| - [AIRFLOW-2429] Fix dag, example_dags, executors flake8 error |
| - [AIRFLOW-2502] Change Single triple quotes to double for docstrings |
| - [AIRFLOW-2503] Fix broken links in CONTRIBUTING.md |
| - [AIRFLOW-2501] Refer to devel instructions in docs contrib guide |
| - [AIRFLOW-2429] Fix contrib folder's flake8 errors |
| - [AIRFLOW-2471] Fix HiveCliHook.load_df to use unused parameters |
| - [AIRFLOW-2495] Update celery to 4.1.1 |
| - [AIRFLOW-2429] Fix api, bin, config_templates folders flake8 error |
| - [AIRFLOW-2493] Mark template_fields of all Operators in the API document as "templated" |
| - [AIRFLOW-2489] Update FlaskAppBuilder to 1.11.1 |
| - [AIRFLOW-2448] Enhance HiveCliHook.load_df to work with datetime |
| - [AIRFLOW-2487] Enhance druid ingestion hook |
| - [AIRFLOW-2397] Support affinity policies for Kubernetes executor/operator |
| - [AIRFLOW-2482] Add test for rewrite method in GCS Hook |
| - [AIRFLOW-2481] Fix flaky Kubernetes test |
| - [AIRFLOW-2479] Improve doc FAQ section |
| - [AIRFLOW-2485] Fix Incorrect logging for Qubole Sensor |
| - [AIRFLOW-2486] Remove unnecessary slash after port |
| - [AIRFLOW-2429] Make Airflow flake8 compliant |
| - [AIRFLOW-2491] Resolve flask version conflict |
| - [AIRFLOW-2484] Remove duplicate key in MySQL to GCS Op |
| - [AIRFLOW-2458] Add cassandra-to-gcs operator |
| - [AIRFLOW-2477] Improve time units for task duration and landing times charts for RBAC UI |
| - [AIRFLOW-2474] Only import snakebite if using py2 |
| - [AIRFLOW-48] Parse connection uri querystring |
| - [AIRFLOW-2467][AIRFLOW-2] Update import direct warn message to use the module name |
| - [AIRFLOW-XXX] Fix order of companies |
| - [AIRFLOW-2452] Document field_dict must be OrderedDict |
| - [AIRFLOW-2420] Azure Data Lake Hook |
| - [AIRFLOW-2213] Add Qubole check operator |
| - [AIRFLOW-2465] Fix wrong module names in the doc |
| - [AIRFLOW-1929] Modifying TriggerDagRunOperator to accept execution_date |
| - [AIRFLOW-2460] Users can now use volume mounts and volumes |
| - [AIRFLOW-2110][AIRFLOW-2122] Enhance Http Hook |
| - [AIRFLOW-XXX] Updated contributors list |
| - [AIRFLOW-2435] Add launch_type to ECSOperator to allow FARGATE |
| - [AIRFLOW-2451] Remove extra slash ('/') char when using wildcard in gcs_to_gcs operator |
| - [AIRFLOW-2461] Add support for cluster scaling on dataproc operator |
| - [AIRFLOW-2376] Fix no hive section error |
| - [AIRFLOW-2425] Add lineage support |
| - [AIRFLOW-2430] Extend query batching to additional slow queries |
| - [AIRFLOW-2453] Add default nil value for kubernetes/git_subpath |
| - [AIRFLOW-2396] Add support for resources in kubernetes operator |
| - [AIRFLOW-2169] Encode binary data with base64 before importing to BigQuery |
| - [AIRFLOW-XXX] Add spotahome in user list |
| - [AIRFLOW-2457] Update FAB version requirement |
| - [AIRFLOW-2454][Airflow 2454] Support imagePullPolicy for k8s |
| - [AIRFLOW-2450] update supported k8s versions to 1.9 and 1.10 |
| - [AIRFLOW-2333] Add Segment Hook and TrackEventOperator |
| - [AIRFLOW-2442][AIRFLOW-2] Airflow run command leaves database connections open |
| - [AIRFLOW-2016] assign template_fields for Dataproc Workflow Template sub-classes, not base class |
| - [AIRFLOW-2446] Add S3ToRedshiftTransfer into the "Integration" doc |
| - [AIRFLOW-2449] Fix operators.py to run all test cases |
| - [AIRFLOW-2424] Add dagrun status endpoint and increased k8s test coverage |
| - [AIRFLOW-2441] Fix bugs in HiveCliHook.load_df |
| - [AIRFLOW-2358][AIRFLOW-201804] Make the Kubernetes example optional |
| - [AIRFLOW-2436] Remove cli_logger in initdb |
| - [AIRFLOW-2444] Remove unused option(include_adhoc) in cli backfill command |
| - [AIRFLOW-2447] Fix TestHiveMetastoreHook to run all cases |
| - [AIRFLOW-2445] Allow templating in kubernetes operator |
| - [AIRFLOW-2086][AIRFLOW-2393] Customize default dagrun number in tree view |
| - [AIRFLOW-2437] Add PubNub to list of current Airflow users |
| - [AIRFLOW-XXX] Add Quantopian to list of Airflow users |
| - [AIRFLOW-1978] Add WinRM windows operator and hook |
| - [AIRFLOW-2427] Add tests to named hive sensor |
| - [AIRFLOW-2412] Fix HiveCliHook.load_file to address HIVE-10541 |
| - [AIRFLOW-2431] Add the navigation bar color parameter for RBAC UI |
| - [AIRFLOW-2407] Resolve Python undefined names |
| - [AIRFLOW-1952] Add the navigation bar color parameter |
| - [AIRFLOW-2222] Implement GoogleCloudStorageHook.rewrite |
| - [AIRFLOW-2426] Add Google Cloud Storage Hook tests |
| - [AIRFLOW-2418] Bump Flask-WTF |
| - [AIRFLOW-2417] Wait for pod is not running to end task |
| - [AIRFLOW-1914] Add other charset support to email utils |
| - [AIRFLOW-XXX] Update README.md with Craig@Work |
| - [AIRFLOW-1899] Fix Kubernetes tests |
| - [AIRFLOW-1812] Update logging example |
| - [AIRFLOW-2313] Add TTL parameters for Dataproc |
| - [AIRFLOW-2411] add dataproc_jars to templated_fields |
| - [AIRFLOW-XXX] Add Reddit to Airflow users |
| - [AIRFLOW-XXX] Fix wrong table header in scheduler.rst |
| - [AIRFLOW-2409] Supply password as a parameter |
| - [AIRFLOW-2410][AIRFLOW-75] Set the timezone in the RBAC Web UI |
| - [AIRFLOW-2394] default cmds and arguments in kubernetes operator |
| - [AIRFLOW-2406] Add Apache2 License Shield to Readme |
| - [AIRFLOW-2404] Add additional documentation for unqueued task |
| - [AIRFLOW-2400] Add Ability to set Environment Variables for K8s |
| - [AIRFLOW-XXX] Add Twine Labs as an Airflow user |
| - [AIRFLOW-1853] Show only the desired number of runs in tree view |
| - [AIRFLOW-2401] Document the use of variables in Jinja template |
| - [AIRFLOW-2403] Fix License Headers |
| - [AIRFLOW-1313] Fix license header |
| - [AIRFLOW-2398] Add BounceX to list of current Airflow users |
| - [AIRFLOW-2363] Fix return type bug in TaskHandler |
| - [AIRFLOW-2389] Create a pinot db api hook |
| - [AIRFLOW-2390] Resolve FlaskWTFDeprecationWarning |
| - [AIRFLOW-1933] Fix some typos |
| - [AIRFLOW-1960] Add support for secrets in kubernetes operator |
| - [AIRFLOW-1313] Add vertica_to_mysql operator |
| - [AIRFLOW-1575] Add AWS Kinesis Firehose Hook for inserting batch records |
| - [AIRFLOW-2266][AIRFLOW-2343] Remove google-cloud-dataflow dependency |
| - [AIRFLOW-2370] Implement --use_random_password in create_user |
| - [AIRFLOW-2348] Strip path prefix from the destination_object when source_object contains a wildcard[] |
| - [AIRFLOW-2391] Fix to Flask 0.12.2 |
| - [AIRFLOW-2381] Fix the flaky ApiPasswordTests test |
| - [AIRFLOW-2378] Add Groupon to list of current users |
| - [AIRFLOW-2382] Fix wrong description for delimiter |
| - [AIRFLOW-2380] Add support for environment variables in Spark submit operator. |
| - [AIRFLOW-2377] Improve Sendgrid sender support |
| - [AIRFLOW-2331] Support init action timeout on dataproc cluster create |
| - [AIRFLOW-1835] Update docs: Variable file is json |
| - [AIRFLOW-1781] Make search case-insensitive in LDAP group |
| - [AIRFLOW-2042] Fix browser menu appearing over the autocomplete menu |
| - [AIRFLOW-XXX] Remove wheelhouse files from travis not owned by travis |
| - [AIRFLOW-2336] Use hmsclient in hive_hook |
| - [AIRFLOW-2041] Correct Syntax in Python examples |
| - [AIRFLOW-74] SubdagOperators can consume all celeryd worker processes |
| - [AIRFLOW-2369] Fix gcs tests |
| - [AIRFLOW-2365] Fix autocommit attribute check |
| - [AIRFLOW-2068] MesosExecutor allows optional Docker image |
| - [AIRFLOW-1652] Push DatabricksRunSubmitOperator metadata into XCOM |
| - [AIRFLOW-2234] Enable insert_rows for PrestoHook |
| - [AIRFLOW-2208][Airflow-22208] Link to same DagRun graph from TaskInstance view |
| - [AIRFLOW-1153] Allow HiveOperators to take hiveconfs |
| - [AIRFLOW-775] Fix autocommit settings with Jdbc hook |
| - [AIRFLOW-2364] Warn when setting autocommit on a connection which does not support it |
| - [AIRFLOW-2357] Add persistent volume for the logs |
| - [AIRFLOW-766] Skip conn.commit() when in Auto-commit |
| - [AIRFLOW-2351] Check for valid default_args start_date |
| - [AIRFLOW-1433] Set default rbac to initdb |
| - [AIRFLOW-2270] Handle removed tasks in backfill |
| - [AIRFLOW-2344] Fix `connections -l` to work with pipe/redirect |
| - [AIRFLOW-2300] Add S3 Select functionality to S3ToHiveTransfer |
| - [AIRFLOW-1314] Cleanup the config |
| - [AIRFLOW-1314] Polish some of the Kubernetes docs/config |
| - [AIRFLOW-1314] Improve error handling |
| - [AIRFLOW-1999] Add per-task GCP service account support |
| - [AIRFLOW-1314] Rebasing against master |
| - [AIRFLOW-1314] Small cleanup to address PR comments (#24) |
| - [AIRFLOW-1314] Add executor_config and tests |
| - [AIRFLOW-1314] Improve k8s support |
| - [AIRFLOW-1314] Use VolumeClaim for transporting DAGs |
| - [AIRFLOW-1314] Create integration testing environment |
| - [AIRFLOW-1314] Git Mode to pull in DAGs for Kubernetes Executor |
| - [AIRFLOW-1314] Add support for volume mounts & Secrets in Kubernetes Executor |
| - [AIRFLOW=1314] Basic Kubernetes Mode |
| - [AIRFLOW-2326][AIRFLOW-2222] remove contrib.gcs_copy_operator |
| - [AIRFLOW-2328] Fix empty GCS blob in S3ToGoogleCloudStorageOperator |
| - [AIRFLOW-2350] Fix grammar in UPDATING.md |
| - [AIRFLOW-2302] Fix documentation |
| - [AIRFLOW-2345] pip is not used in this setup.py |
| - [AIRFLOW-2347] Add Banco de Formaturas to Readme |
| - [AIRFLOW-2346] Add Investorise as official user of Airflow |
| - [AIRFLOW-2330] Do not append destination prefix if not given |
| - [AIRFLOW-2240][DASK] Added TLS/SSL support for the dask-distributed scheduler. |
| - [AIRFLOW-2309] Fix duration calculation on TaskFail |
| - [AIRFLOW-2335] fix issue with jdk8 download for ci |
| - [AIRFLOW-2184] Add druid_checker_operator |
| - [AIRFLOW-2299] Add S3 Select functionality to S3FileTransformOperator |
| - [AIRFLOW-2254] Put header as first row in unload |
| - [AIRFLOW-610] Respect _cmd option in config before defaults |
| - [AIRFLOW-2287] Fix incorrect ASF headers |
| - [AIRFLOW-XXX] Add Zego as an Apache Airflow user |
| - [AIRFLOW-952] fix save empty extra field in UI |
| - [AIRFLOW-1325] Add ElasticSearch log handler and reader |
| - [AIRFLOW-2301] Sync files of an S3 key with a GCS path |
| - [AIRFLOW-2293] Fix S3FileTransformOperator to work with boto3 |
| - [AIRFLOW-3212][AIRFLOW-2314] Remove only leading slash in GCS path |
| - [AIRFLOW-1509][AIRFLOW-442] SFTP Sensor |
| - [AIRFLOW-2291] Add optional params to ML Engine |
| - [AIRFLOW-1774] Allow consistent templating of arguments in MLEngineBatchPredictionOperator |
| - [AIRFLOW-2302] Add missing operators and hooks |
| - [AIRFLOW-2312] Docs Typo Correction: Corresponding |
| - [AIRFLOW-1623] Trigger on_kill method in operators |
| - [AIRFLOW-2162] When impersonating another user, pass env variables to sudo |
| - [AIRFLOW-2304] Update quickstart doc to mention scheduler part |
| - [AIRFLOW-1633] docker_operator needs a way to set shm_size |
| - [AIRFLOW-1340] Add S3 to Redshift transfer operator |
| - [AIRFLOW-2303] Lists the keys inside an S3 bucket |
| - [AIRFLOW-2209] restore flask_login imports |
| - [AIRFLOW-2306] Add Bonnier Broadcasting to list of current users |
| - [AIRFLOW-2305][AIRFLOW-2027] Fix CI failure caused by [] |
| - [AIRFLOW-2281] Add support for Sendgrid categories |
| - [AIRFLOW-2027] Only trigger sleep in scheduler after all files have parsed |
| - [AIRFLOW-2256] SparkOperator: Add Client Standalone mode and retry mechanism |
| - [AIRFLOW-2284] GCS to S3 operator |
| - [AIRFLOW-2287] Update license notices |
| - [AIRFLOW-2296] Add Cinimex DataLab to Readme |
| - [AIRFLOW-2298] Add Kalibrr to who uses Airflow |
| - [AIRFLOW-2292] Fix docstring for S3Hook.get_wildcard_key |
| - [AIRFLOW-XXX] Update PR template |
| - [AIRFLOW-XXX] Remove outdated migrations.sql |
| - [AIRFLOW-2287] Add license header to docs/Makefile |
| - [AIRFLOW-2286] Add tokopedia to the readme |
| - [AIRFLOW-2273] Add Discord webhook operator/hook |
| - [AIRFLOW-2282] Fix grammar in UPDATING.md |
| - [AIRFLOW-2200] Add snowflake operator with tests |
| - [AIRFLOW-2178] Add handling on SLA miss errors |
| - [AIRFLOW-2169] Fix type 'bytes' is not JSON serializable in python3 |
| - [AIRFLOW-2215] Pass environment to subprocess.Popen in base_task_runner |
| - [AIRFLOW-2253] Add Airflow CLI instrumentation |
| - [AIRFLOW-2274] Fix Dataflow tests |
| - [AIRFLOW-2269] Add Custom Ink as an Airflow user |
| - [AIRFLOW-2259] Dataflow Hook Index out of range |
| - [AIRFLOW-2233] Update updating.md to include the info of hdfs_sensors renaming |
| - [AIRFLOW-2217] Add Slack webhook operator |
| - [AIRFLOW-1729] improve DagBag time |
| - [AIRFLOW-2264] Improve create_user cli help message |
| - [AIRFLOW-2260][AIRFLOW-2260] SSHOperator add command template .sh files |
| - [AIRFLOW-2261] Check config/env for remote base log folder |
| - [AIRFLOW-2258] Allow import of Parquet-format files into BigQuery |
| - [AIRFLOW-1430] Include INSTALL instructions to avoid GPL |
| - [AIRFLOW-1430] Solve GPL dependency |
| - [AIRFLOW-2251] Add Thinknear as an Airflow user |
| - [AIRFLOW-2244] bugfix: remove legacy LongText code from models.py |
| - [AIRFLOW-2247] Fix RedshiftToS3Transfer not to fail with ValueError |
| - [AIRFLOW-2249] Add side-loading support for Zendesk Hook |
| - [AIRFLOW-XXX] Add Qplum to Airflow users |
| - [AIRFLOW-2228] Enhancements in ValueCheckOperator |
| - [AIRFLOW-1206] Typos |
| - [AIRFLOW-2060] Update pendulum version to 1.4.4 |
| - [AIRFLOW-2248] Fix wrong param name in RedshiftToS3Transfer doc |
| - [AIRFLOW-1433][AIRFLOW-85] New Airflow Webserver UI with RBAC support |
| - [AIRFLOW-1235] Fix webserver's odd behaviour |
| - [AIRFLOW-1460] Allow restoration of REMOVED TI's |
| - [AIRFLOW-2235] Fix wrong docstrings in two operators |
| - [AIRFLOW-XXX] Fix chronological order for companies using Airflow |
| - [AIRFLOW-2124] Upload Python file to a bucket for Dataproc |
| - [AIRFLOW-2212] Fix ungenerated sensor API reference |
| - [AIRFLOW-2226] Rename google_cloud_storage_default to google_cloud_default |
| - [AIRFLOW-2211] Rename hdfs_sensors.py to hdfs_sensor.py for consistency |
| - [AIRFLOW-2225] Update document to include DruidDbApiHook |
| - [Airflow-2202] Add filter support in HiveMetastoreHook().max_partition() |
| - [AIRFLOW-2220] Remove duplicate numeric list entry in security.rst |
| - [AIRFLOW-XXX] Update tutorial documentation |
| - [AIRFLOW-2215] Update celery task to preserve environment variables and improve logging on exception |
| - [AIRFLOW-2185] Use state instead of query param |
| - [AIRFLOW-2183] Refactor DruidHook to enable sql |
| - [AIRFLOW-2203] Defer cycle detection |
| - [AIRFLOW-2203] Remove Useless Commands. |
| - [AIRFLOW-2203] Cache signature in apply_defaults |
| - [AIRFLOW-2203] Speed up Operator Resources |
| - [AIRFLOW-2203] Cache static rules (trigger/weight) |
| - [AIRFLOW-2203] Store task ids as sets not lists |
| - [AIRFLOW-2205] Remove unsupported args from JdbcHook doc |
| - [AIRFLOW-2207] Fix flaky test that uses app.cached_app() |
| - [AIRFLOW-2206] Remove unsupported args from JdbcOperator doc |
| - [AIRFLOW-2140] Add Kubernetes scheduler to SparkSubmitOperator |
| - [AIRFLOW-XXX] Add Xero to list of users |
| - [AIRFLOW-2204] Fix webserver debug mode |
| - [AIRFLOW-102] Fix test_complex_template always succeeds |
| - [AIRFLOW-442] Add SFTPHook |
| - [AIRFLOW-2169] Add schema to MySqlToGoogleCloudStorageOperator |
| - [AIRFLOW-2184][AIRFLOW-2138] Google Cloud Storage allow wildcards |
| - [AIRFLOW-1588] Cast Variable value to string |
| - [AIRFLOW-2199] Fix invalid reference to logger |
| - [AIRFLOW-2191] Change scheduler heartbeat logs from info to debug |
| - [AIRFLOW-2106] SalesForce hook sandbox option |
| - [AIRFLOW-2197] Silence hostname_callable config error message |
| - [AIRFLOW-2150] Use lighter call in HiveMetastoreHook().max_partition() |
| - [AIRFLOW-2186] Change the way logging is carried out in few ops |
| - [AIRFLOW-2181] Convert password_auth and test_password_endpoints from DOS to UNIX |
| - [AIRFLOW-2187] Fix Broken Travis CI due to AIRFLOW-2123 |
| - [AIRFLOW-2175] Check that filepath is not None |
| - [AIRFLOW-2173] Don't check task IDs for concurrency reached check |
| - [AIRFLOW-2168] Remote logging for Azure Blob Storage |
| - [AIRFLOW-XXX] Add DocuTAP to list of users |
| - [AIRFLOW-2176] Change the way logging is carried out in BQ Get Data Operator |
| - [AIRFLOW-2177] Add mock test for GCS Download op |
| - [AIRFLOW-2123] Install CI dependencies from setup.py |
| - [AIRFLOW-2129] Presto hook calls _parse_exception_message but defines _get_pretty_exception_message |
| - [AIRFLOW-2174] Fix typos and wrongly rendered documents |
| - [AIRFLOW-2171] Store delegated credentials |
| - [AIRFLOW-2166] Restore BQ run_query dialect param |
| - [AIRFLOW-2163] Add HBC Digital to users of Airflow |
| - [AIRFLOW-2065] Fix race-conditions when creating loggers |
| - [AIRFLOW-2147] Plugin manager: added 'sensors' attribute |
| - [AIRFLOW-2059] taskinstance query is awful, un-indexed, and does not scale |
| - [AIRFLOW-2159] Fix a few typos in salesforce_hook |
| - [AIRFLOW-2132] Add step to initialize database |
| - [AIRFLOW-2160] Fix bad rowid deserialization |
| - [AIRFLOW-2161] Add Vevo to list of companies using Airflow |
| - [AIRFLOW-2149] Add link to apache Beam documentation to create self executing Jar |
| - [AIRFLOW-2151] Allow getting the session from AwsHook |
| - [AIRFLOW-2097] tz referenced before assignment |
| - [AIRFLOW-2152] Add Multiply to list of companies using Airflow |
| - [AIRFLOW-1551] Add operator to trigger Jenkins job |
| - [AIRFLOW-2034] Fix mixup between %s and {} when using str.format Convention is to use .format for string formatting outside logging, else use lazy format See comment in related issue https://github.com/apache/airflow/pull/2823/files Identified problematic case using following command line .git/COMMIT_EDITMSG:`grep -r '%s'./* | grep '\.format('` |
| - [AIRFLOW-2102] Add custom_args to Sendgrid personalizations |
| - [AIRFLOW-1035][AIRFLOW-1053] import unicode_literals to parse Unicode in HQL |
| - [AIRFLOW-2127] Keep loggers during DB migrations |
| - [AIRFLOW-2146] Resolve issues with BQ using DbApiHook methods |
| - [AIRFLOW-2087] Scheduler Report shows incorrect Total task number |
| - [AIRFLOW-2139] Remove unnecessary boilerplate to get DataFrame using pandas_gbq |
| - [AIRFLOW-2125] Using binary package psycopg2-binary |
| - [AIRFLOW-2142] Include message on mkdir failure |
| - [AIRFLOW-1615] SSHHook: use port specified by Connection |
| - [AIRFLOW-2122] Handle boolean values in sshHook |
| - [AIRFLOW-XXX] Add Tile to the list of users |
| - [AIRFLOW-2130] Add missing Operators to API Reference docs |
| - [AIRFLOW-XXX] Add timeout units (seconds) |
| - [AIRFLOW-2134] Add Alan to the list of companies that use Airflow |
| - [AIRFLOW-2133] Remove references to GitHub issues in CONTRIBUTING |
| - [AIRFLOW-2131] Remove confusing AirflowImport docs |
| - [AIRFLOW-1852] Allow hostname to be overridable. |
| - [AIRFLOW-2126] Add Bluecore to active users |
| - [AIRFLOW-1618] Add feature to create GCS bucket |
| - [AIRFLOW-2108] Fix log indentation in BashOperator |
| - [AIRFLOW-2115] Fix doc links to PythonHosted |
| - [AIRFLOW-XXX] Add contributor from Easy company |
| - [AIRFLOW-1882] Add ignoreUnknownValues option to gcs_to_bq operator |
| - [AIRFLOW-2089] Add on kill for SparkSubmit in Standalone Cluster |
| - [AIRFLOW-2113] Address missing DagRun callbacks Given that the handle_callback method belongs to the DAG object, we are able to get the list of task directly with get_task and reduce the communication with the database, making Airflow more lightweight. |
| - [AIRFLOW-2112] Fix svg width for Recent Tasks on UI. |
| - [AIRFLOW-2116] Set CI Cloudant version to <2.0 |
| - [AIRFLOW-XXX] Add PMC to list of companies using Airflow |
| - [AIRFLOW-2100] Fix Broken Documentation Links |
| - [AIRFLOW-1404] Add 'flatten_results' & 'maximum_bytes_billed' to BQ Operator |
| - [AIRFLOW-800] Initialize valid Google BigQuery Connection |
| - [AIRFLOW-1319] Fix misleading SparkSubmitOperator and SparkSubmitHook docstring |
| - [AIRFLOW-1983] Parse environment parameter as template |
| - [AIRFLOW-2095] Add operator to create External BigQuery Table |
| - [AIRFLOW-2085] Add SparkJdbc operator |
| - [AIRFLOW-1002] Add ability to clean all dependencies of removed DAG |
| - [AIRFLOW-2094] Jinjafied project_id, region & zone in DataProc{*} Operators |
| - [AIRFLOW-2092] Fixed incorrect parameter in docstring for FTPHook |
| - [AIRFLOW-XXX] Add SocialCops to Airflow users |
| - [AIRFLOW-2088] Fix duplicate keys in MySQL to GCS Helper function |
| - [AIRFLOW-2091] Fix incorrect docstring parameter in BigQuery Hook |
| - [AIRFLOW-2090] Fix typo in DataStore Hook |
| - [AIRFLOW-1157] Fix missing pools crashing the scheduler |
| - [AIRFLOW-713] Jinjafy {EmrCreateJobFlow,EmrAddSteps}Operator attributes |
| - [AIRFLOW-2083] Docs: Use "its" instead of "it's" where appropriate |
| - [AIRFLOW-2066] Add operator to create empty BQ table |
| - [AIRFLOW-XXX] add Karmic to list of companies |
| - [AIRFLOW-2073] Make FileSensor fail when the file doesn't exist |
| - [AIRFLOW-2078] Improve task_stats and dag_stats performance |
| - [AIRFLOW-2080] Use a log-out icon instead of a power button |
| - [AIRFLOW-2077] Fetch all pages of list_objects_v2 response |
| - [AIRFLOW-XXX] Add TM to list of companies |
| - [AIRFLOW-1985] Impersonation fixes for using `run_as_user` |
| - [AIRFLOW-2018][AIRFLOW-2] Make Sensors backward compatible |
| - [AIRFLOW-XXX] Fix typo in concepts doc (dag_md) |
| - [AIRFLOW-2069] Allow Bytes to be uploaded to S3 |
| - [AIRFLOW-2074] Fix log var name in GHE auth |
| - [AIRFLOW-1927] Convert naive datetimes for TaskInstances |
| - [AIRFLOW-1760] Password auth for experimental API |
| - [AIRFLOW-2038] Add missing kubernetes dependency for dev |
| - [AIRFLOW-2040] Escape special chars in task instance logs URL |
| - [AIRFLOW-1968][AIRFLOW-1520] Add role_arn and aws_account_id/aws_iam_role support back to aws hook |
| - [AIRFLOW-2048] Fix task instance failure string formatting |
| - [AIRFLOW-2046] Fix kerberos error to work with Python 3.x |
| - [AIRFLOW-2063] Add missing docs for GCP |
| - [AIRFLOW-XXX] Fix typo in docs |
| - [AIRFLOW-1793] Use docker_url instead of invalid base_url |
| - [AIRFLOW-2055] Elaborate on slightly ambiguous documentation |
| - [AIRFLOW-2039] BigQueryOperator supports priority property |
| - [AIRFLOW-2053] Fix quote character bug in BQ hook |
| - [AIRFLOW-2057] Add Overstock to list of companies |
| - [AIRFLOW-XXX] Add Plaid to Airflow users |
| - [AIRFLOW-2044] Add SparkSubmitOperator to documentation |
| - [AIRFLOW-2037] Add methods to get Hash values of a GCS object |
| - [AIRFLOW-2050] Fix Travis permission problem |
| - [AIRFLOW-2043] Add Intercom to list of companies |
| - [AIRFLOW-2023] Add debug logging around number of queued files |
| - [AIRFLOW-XXX] Add Pernod-ricard as an Airflow user |
| - [AIRFLOW-1453] Add 'steps' into template_fields in EmrAddSteps |
| - [AIRFLOW-2015] Add flag for interactive runs |
| - [AIRFLOW-1895] Fix primary key integrity for mysql |
| - [AIRFLOW-2030] Fix KeyError:`i` in DbApiHook for insert |
| - [AIRFLOW-1943] Add External BigQuery Table feature |
| - [AIRFLOW-2033] Add Google Cloud Storage List Operator |
| - [AIRFLOW-2006] Add local log catching to kubernetes operator |
| - [AIRFLOW-2031] Add missing gcp_conn_id in the example in DataFlow docstrings |
| - [AIRFLOW-2029] Fix AttributeError in BigQueryPandasConnector |
| - [AIRFLOW-2028] Add JobTeaser to official users list |
| - [AIRFLOW-2016] Add support for Dataproc Workflow Templates |
| - [AIRFLOW-2025] Reduced Logging verbosity |
| - [AIRFLOW-1267][AIRFLOW-1874] Add dialect parameter to BigQueryHook |
| - [AIRFLOW-XXX] Fixed a typo |
| - [AIRFLOW-XXX] Typo node to nodes |
| - [AIRFLOW-2019] Update DataflowHook for updating Streaming type job |
| - [AIRFLOW-2017][Airflow 2017] adding query output to PostgresOperator |
| - [AIRFLOW-1889] Split sensors into separate files |
| - [AIRFLOW-1950] Optionally pass xcom_pull task_ids |
| - [AIRFLOW-1755] Allow mount below root |
| - [AIRFLOW-511][Airflow 511] add success/failure callbacks on dag level |
| - [AIRFLOW-192] Add weight_rule param to BaseOperator |
| - [AIRFLOW-2008] Use callable for Python column defaults |
| - [AIRFLOW-1984] Fix to AWS Batch operator |
| - [AIRFLOW-2000] Support non-main dataflow job class |
| - [AIRFLOW-2003] Use flask-caching instead of flask-cache |
| - [AIRFLOW-2002] Do not swallow exception on logging import |
| - [AIRFLOW-2004] Import flash from flask not flask.login |
| - [AIRFLOW-1997] Fix GCP operator doc strings |
| - [AIRFLOW-1996] Update DataflowHook wait_for_done for Streaming type job |
| - [AIRFLOW-1995][Airflow 1995] add on_kill method to SqoopOperator |
| - [AIRFLOW-1770] Allow HiveOperator to take in a file |
| - [AIRFLOW-1994] Change background color of Scheduled state Task Instances |
| - [AIRFLOW-1436][AIRFLOW-1475] EmrJobFlowSensor considers Cancelled step as Successful |
| - [AIRFLOW-1517] Kubernetes operator PR fixes |
| - [AIRFLOW-1517] Addressed PR comments |
| - [AIRFLOW-1517] Started documentation of k8s operator |
| - [AIRFLOW-1517] Restore authorship of resources |
| - [AIRFLOW-1517] Remove authorship of resources |
| - [AIRFLOW-1517] Add minikube for kubernetes integration tests |
| - [AIRFLOW-1517] Restore authorship of resources |
| - [AIRFLOW-1517] fixed license issues |
| - [AIRFLOW-1517] Created more accurate failures for kube cluster issues |
| - [AIRFLOW-1517] Remove authorship of resources |
| - [AIRFLOW-1517] Add minikube for kubernetes integration tests |
| - [AIRFLOW-1988] Change BG color of None state TIs |
| - [AIRFLOW-790] Clean up TaskInstances without DagRuns |
| - [AIRFLOW-1949] Fix var upload, str() produces "b'...'" which is not json |
| - [AIRFLOW-1930] Convert func.now() to timezone.utcnow() |
| - [AIRFLOW-1688] Support load.time_partitioning in bigquery_hook |
| - [AIRFLOW-1975] Make TriggerDagRunOperator callback optional |
| - [AIRFLOW-1480] Render template attributes for ExternalTaskSensor fields |
| - [AIRFLOW-1958] Add kwargs to send_email |
| - [AIRFLOW-1976] Fix for missing log/logger attribute FileProcessHandler |
| - [AIRFLOW-1982] Fix Executor event log formatting |
| - [AIRFLOW-1971] Propagate hive config on impersonation |
| - [AIRFLOW-1969] Always use HTTPS URIs for Google OAuth2 |
| - [AIRFLOW-1954] Add DataFlowTemplateOperator |
| - [AIRFLOW-1963] Add config for HiveOperator mapred_queue |
| - [AIRFLOW-1946][AIRFLOW-1855] Create a BigQuery Get Data Operator |
| - [AIRFLOW-1953] Add labels to dataflow operators |
| - [AIRFLOW-1967] Update celery to 4.0.2 |
| - [AIRFLOW-1964] Add Upsight to list of Airflow users |
| - [AIRFLOW-XXX] Changelog for 1.9.0 |
| - [AIRFLOW-1470] Implement BashSensor operator |
| - [AIRFLOW-XXX] Pin sqlalchemy dependency |
| - [AIRFLOW-1955] Do not reference unassigned variable |
| - [AIRFLOW-1957] Add contributor to BalanceHero in Readme |
| - [AIRFLOW-1517] Restore authorship of secrets and init container |
| - [AIRFLOW-1517] Remove authorship of secrets and init container |
| - [AIRFLOW-1935] Add BalanceHero to readme |
| - [AIRFLOW-1939] add astronomer contributors |
| - [AIRFLOW-1517] Kubernetes Operator |
| - [AIRFLOW-1928] Fix @once with catchup=False |
| - [AIRFLOW-1937] Speed up scheduling by committing in batch |
| - [AIRFLOW-1821] Enhance default logging config by removing extra loggers |
| - [AIRFLOW-1904] Correct DAG fileloc to the right filepath |
| - [AIRFLOW-1909] Update docs with supported versions of MySQL server |
| - [AIRFLOW-1915] Relax flask-wtf dependency specification |
| - [AIRFLOW-1920] Update CONTRIBUTING.md to reflect enforced linting rules |
| - [AIRFLOW-1942] Update Sphinx docs to remove deprecated import structure |
| - [AIRFLOW-1846][AIRFLOW-1697] Hide Ad Hoc Query behind secure_mode config |
| - [AIRFLOW-1948] Include details for on_kill failure |
| - [AIRFLOW-1938] Clean up unused exception |
| - [AIRFLOW-1932] Add GCP Pub/Sub Pull and Ack |
| - [AIRFLOW-XXX] Purge coveralls |
| - [AIRFLOW-XXX] Remove unused coveralls token |
| - [AIRFLOW-1938] Remove tag version check in setup.py |
| - [AIRFLOW-1916] Don't upload logs to remote from `run --raw` |
| - [AIRFLOW-XXX] Fix failing PubSub tests on Python3 |
| - [AIRFLOW-XXX] Upgrade to Python 3.5 and disable dask tests |
| - [AIRFLOW-1913] Add new GCP PubSub operators |
| - [AIRFLOW-1525] Fix minor LICENSE and NOTICE issues |
| - [AIRFLOW-1687] fix fernet error without encryption |
| - [AIRFLOW-1912] airflow.processor should not propagate logging |
| - [AIRFLOW-1911] Rename celeryd_concurrency |
| - [AIRFLOW-1885] Fix IndexError in ready_prefix_on_cmdline |
| - [AIRFLOW-1854] Improve Spark Submit operator for standalone cluster mode |
| - [AIRFLOW-1908] Fix celery broker options config load |
| - [AIRFLOW-1907] Pass max_ingestion_time to Druid hook |
| - [AIRFLOW-1909] Add away to list of users |
| - [AIRFLOW-1893][AIRFLOW-1901] Propagate PYTHONPATH when using impersonation |
| - [AIRFLOW-1892] Modify BQ hook to extract data filtered by column |
| - [AIRFLOW-1829] Support for schema updates in query jobs |
| - [AIRFLOW-1840] Make celery configuration congruent with Celery 4 |
| - [AIRFLOW-1878] Fix stderr/stdout redirection for tasks |
| - [AIRFLOW-1897][AIRFLOW-1873] Task Logs for running instance not visible in WebUI |
| - [AIRFLOW-1896] FIX bleach <> html5lib incompatibility |
| - [AIRFLOW-1884][AIRFLOW-1059] Reset orphaned task state for external dagruns |
| - [AIRFLOW-XXX] Fix typo in comment |
| - [AIRFLOW-1869] Do not emit spurious warning on missing logs |
| - [AIRFLOW-1888] Add AWS Redshift Cluster Sensor |
| - [AIRFLOW-1887] Renamed endpoint url variable |
| - [AIRFLOW-1873] Set TI.try_number to right value depending TI state |
| - [AIRFLOW-1891] Fix non-ascii typo in default configuration template |
| - [AIRFLOW-1879] Handle ti log entirely within ti |
| - [AIRFLOW-1869] Write more error messages into gcs and file logs |
| - [AIRFLOW-1876] Write subtask id to task log header |
| - [AIRFLOW-1554] Fix wrong DagFileProcessor termination method call |
| - [AIRFLOW-342] Do not use amqp, rpc as result backend |
| - [AIRFLOW-966] Make celery broker_transport_options configurable |
| - [AIRFLOW-1881] Make operator log in task log |
| - [AIRFLOW-XXX] Added DataReply to the list of Airflow Users |
| - [AIRFLOW-1883] Get File Size for objects in Google Cloud Storage |
| - [AIRFLOW-1872] Set context for all handlers including parents |
| - [AIRFLOW-1855][AIRFLOW-1866] Add GCS Copy Operator to copy multiple files |
| - [AIRFLOW-1870] Enable flake8 tests |
| - [AIRFLOW-1785] Enable Python 3 tests |
| - [AIRFLOW-1850] Copy cmd before masking |
| - [AIRFLOW-1665] Reconnect on database errors |
| - [AIRFLOW-1559] Dispose SQLAlchemy engines on exit |
| - [AIRFLOW-1559] Close file handles in subprocesses |
| - [AIRFLOW-1559] Make database pooling optional |
| - [AIRFLOW-1848][Airflow-1848] Fix DataFlowPythonOperator py_file extension doc comment |
| - [AIRFLOW-1843] Add Google Cloud Storage Sensor with prefix |
| - [AIRFLOW-1803] Time zone documentation |
| - [AIRFLOW-1826] Update views to use timezone aware objects |
| - [AIRFLOW-1827] Fix api endpoint date parsing |
| - [AIRFLOW-1806] Use naive datetime when using cron |
| - [AIRFLOW-1809] Update tests to use timezone aware objects |
| - [AIRFLOW-1806] Use naive datetime for cron scheduling |
| - [AIRFLOW-1807] Force use of time zone aware db fields |
| - [AIRFLOW-1808] Convert all utcnow() to time zone aware |
| - [AIRFLOW-1804] Add time zone configuration options |
| - [AIRFLOW-1802] Convert database fields to timezone aware |
| - [AIRFLOW-XXX] Add dask lock files to excludes |
| - [AIRFLOW-1790] Add support for AWS Batch operator |
| - [AIRFLOW-XXX] Update README.md |
| - [AIRFLOW-1820] Remove timestamp from metric name |
| - [AIRFLOW-1810] Remove unused mysql import in migrations. |
| - [AIRFLOW-1838] Properly log collect_dags exception |
| - [AIRFLOW-1842] Fixed Super class name for the gcs to gcs copy operator |
| - [AIRFLOW-1845] Modal background now covers long or tall pages |
| - [AIRFLOW-1229] Add link to Run Id, incl execution_date |
| - [AIRFLOW-1842] Add gcs to gcs copy operator with renaming if required |
| - [AIRFLOW-1841] change False to None in operator and hook |
| - [AIRFLOW-1839] Fix more bugs in S3Hook boto -> boto3 migration |
| - [AIRFLOW-1830] Support multiple domains in Google authentication backend |
| - [AIRFLOW-1831] Add driver-classpath spark submit |
| - [AIRFLOW-1795] Correctly call S3Hook after migration to boto3 |
| - [AIRFLOW-1811] Fix render Druid operator |
| - [AIRFLOW-1819] Fix slack operator unittest bug |
| - [AIRFLOW-1805] Allow Slack token to be passed through connection |
| - [AIRFLOW-1816] Add region param to Dataproc operators |
| - [AIRFLOW-868] Add postgres_to_gcs operator and unittests |
| - [AIRFLOW-1613] make mysql_to_gcs_operator py3 compatible |
| - [AIRFLOW-1817] use boto3 for s3 dependency |
| - [AIRFLOW-1813] Bug SSH Operator empty buffer |
| - [AIRFLOW-1801][AIRFLOW-288] Url encode execution dates |
| - [AIRFLOW-1563] Catch OSError while symlinking the latest log directory |
| - [AIRFLOW-1794] Remove uses of Exception.message for Python 3 |
| - [AIRFLOW-1799] Fix logging line which raises errors |
| - [AIRFLOW-1102] Upgrade gunicorn >=19.4.0 |
| - [AIRFLOW-1756] Fix S3TaskHandler to work with Boto3-based S3Hook |
| - [AIRFLOW-1797] S3Hook.load_string did not work on Python3 |
| - [AIRFLOW-646] Add docutils to setup_requires |
| - [AIRFLOW-1792] Missing intervals DruidOperator |
| - [AIRFLOW-1789][AIRFLOW-1712] Log SSHOperator stderr to log.warning |
| - [AIRFLOW-1787] Fix task instance batch clear and set state bugs |
| - [AIRFLOW-1780] Fix long output lines with unicode from hanging parent |
| - [AIRFLOW-387] Close SQLAlchemy sessions properly |
| - [AIRFLOW-1779] Add keepalive packets to ssh hook |
| - [AIRFLOW-1669] Fix Docker and pin moto to 1.1.19 |
| - [AIRFLOW-71] Add support for private Docker images |
| - [AIRFLOW-XXX] Give a clue what the 'ds' variable is |
| - [AIRFLOW-XXX] Correct typos in the faq docs page |
| - [AIRFLOW-1571] Add AWS Lambda Hook |
| - [AIRFLOW-1675] Fix docstrings for API docs |
| - [AIRFLOW-1712][AIRFLOW-756][AIRFLOW-751] Log SSHOperator output |
| - [AIRFLOW-1776] Capture stdout and stderr for logging |
| - [AIRFLOW-1765] Make experimental API securable without needing Kerberos. |
| - [AIRFLOW-1764] The web interface should not use the experimental API |
| - [AIRFLOW-1771] Rename heartbeat to avoid confusion |
| - [AIRFLOW-1769] Add support for templates in VirtualenvOperator |
| - [AIRFLOW-1763] Fix S3TaskHandler unit tests |
| - [AIRFLOW-1315] Add Qubole File & Partition Sensors |
| - [AIRFLOW-1018] Make processor use logging framework |
| - [AIRFLOW-1695] Add RedshiftHook using boto3 |
| - [AIRFLOW-1706] Fix query error for MSSQL backend |
| - [AIRFLOW-1711] Use ldap3 dict for group membership |
| - [AIRFLOW-1723] Make sendgrid a plugin |
| - [AIRFLOW-1757] Add missing options to SparkSubmitOperator |
| - [AIRFLOW-1734][Airflow 1734] Sqoop hook/operator enhancements |
| - [AIRFLOW-1761] Fix type in scheduler.rst |
| - [AIRFLOW-1731] Set pythonpath for logging |
| - [AIRFLOW-1641] Handle executor events in the scheduler |
| - [AIRFLOW-1744] Make sure max_tries can be set |
| - [AIRFLOW-1732] Improve dataflow hook logging |
| - [AIRFLOW-1736] Add HotelQuickly to Who Uses Airflow |
| - [AIRFLOW-1657] Handle failing qubole operator |
| - [AIRFLOW-1677] Fix typo in example_qubole_operator |
| - [AIRFLOW-926] Fix JDBC Hook |
| - [AIRFLOW-1520] Boto3 S3Hook, S3Log |
| - [AIRFLOW-1716] Fix multiple __init__ def in SimpleDag |
| - [AIRFLOW-XXX] Fix DateTime in Tree View |
| - [AIRFLOW-1719] Fix small typo |
| - [AIRFLOW-1432] Charts label for Y axis not visible |
| - [AIRFLOW-1743] Verify ldap filters correctly |
| - [AIRFLOW-1745] Restore default signal disposition |
| - [AIRFLOW-1741] Correctly hide second chart on task duration page |
| - [AIRFLOW-1728] Add networkUri, subnet, tags to Dataproc operator |
| - [AIRFLOW-1726] Add copy_expert psycopg2 method to PostgresHook |
| - [AIRFLOW-1330] Add conn_type argument to CLI when adding connection |
| - [AIRFLOW-1698] Remove SCHEDULER_RUNS env var in systemd |
| - [AIRFLOW-1694] Stop using itertools.izip |
| - [AIRFLOW-1692] Change test_views filename to support Windows |
| - [AIRFLOW-1722] Fix typo in scheduler autorestart output filename |
| - [AIRFLOW-1723] Support sendgrid in email backend |
| - [AIRFLOW-1718] Set num_retries on Dataproc job request execution |
| - [AIRFLOW-1727] Add unit tests for DataProcHook |
| - [AIRFLOW-1631] Fix timing issue in unit test |
| - [AIRFLOW-1631] Fix local executor unbound parallelism |
| - [AIRFLOW-1724] Add Fundera to Who uses Airflow? |
| - [AIRFLOW-1683] Cancel BigQuery job on timeout. |
| - [AIRFLOW-1714] Fix misspelling: s/separate/separate/ |
| - [AIRFLOW-1681] Add batch clear in task instance view |
| - [AIRFLOW-1696] Fix dataproc version label error |
| - [AIRFLOW-1613] Handle binary field in MySqlToGoogleCloudStorageOperator |
| - [AIRFLOW-1697] Mode to disable charts endpoint |
| - [AIRFLOW-1691] Add better Google cloud logging documentation |
| - [AIRFLOW-1690] Add detail to gcs error messages |
| - [AIRFLOW-1682] Make S3TaskHandler write to S3 on close |
| - [AIRFLOW-1634] Adds task_concurrency feature |
| - [AIRFLOW-1676] Make GCSTaskHandler write to GCS on close |
| - [AIRFLOW-1678] Fix erroneously repeated word in function docstrings |
| - [AIRFLOW-1323] Made Dataproc operator parameter names consistent |
| - [AIRFLOW-1590] fix unused module and variable |
| - [AIRFLOW-1671] Add @apply_defaults back to gcs download operator |
| - [AIRFLOW-988] Fix repeating SLA miss callbacks |
| - [AIRFLOW-1611] Customize logging |
| - [AIRFLOW-1668] Expose keepalives_idle for Postgres connections |
| - [AIRFLOW-1658] Kill Druid task on timeout |
| - [AIRFLOW-1669][AIRFLOW-1368] Fix Docker import |
| - [AIRFLOW-891] Make webserver clock include date |
| - [AIRFLOW-1560] Add AWS DynamoDB hook and operator for inserting batch items |
| - [AIRFLOW-1654] Show tooltips for link icons in DAGs view |
| - [AIRFLOW-1660] Change webpage width to full-width |
| - [AIRFLOW-1664] write file as binary instead of str |
| - [AIRFLOW-1659] Fix invalid obj attribute bug in file_task_handler.py |
| - [AIRFLOW-1635] Allow creating GCP connection without requiring a JSON file |
| - [AIRFLOW-1650] Fix custom celery config loading |
| - [AIRFLOW-1647] Fix Spark-sql hook |
| - [AIRFLOW-1587] Fix CeleryExecutor import error |
| - [Airflow-1640][AIRFLOW-1640] Add qubole default connection |
| - [AIRFLOW-1576] Added region param to Dataproc{*}Operators |
| - [AIRFLOW-1643] Add healthjump to officially using list |
| - [AIRFLOW-1626] Add Azri Solutions to Airflow users |
| - [AIRFLOW-1636] Add AWS and EMR connection type |
| - [AIRFLOW-1527] Refactor celery config |
| - [AIRFLOW-1639] Fix Fernet error handling |
| - [AIRFLOW-1637] Fix Travis CI build status link |
| - [AIRFLOW-1628] Fix docstring of sqlsensor |
| - [AIRFLOW-1331] add SparkSubmitOperator option |
| - [AIRFLOW-1627] Only query pool in SubDAG init when necessary |
| - [AIRFLOW-1629] Make extra a textarea in edit connections form |
| - [AIRFLOW-1368] Automatically remove Docker container on exit |
| - [AIRFLOW-289] Make Airflow timezone independent |
| - [AIRFLOW-1356] Add `--celery_hostname` to `airflow worker` |
| - [AIRFLOW-1247] Fix ignore_all_dependencies argument ignored |
| - [AIRFLOW-1621] Add tests for server side paging |
| - [AIRFLOW-1591] Avoid attribute error when rendering logging filename |
| - [AIRFLOW-1031] Replace hard-code to DagRun.ID_PREFIX |
| - [AIRFLOW-1604] Rename logger to log |
| - [AIRFLOW-1512] Add PythonVirtualenvOperator |
| - [AIRFLOW-1617] Fix XSS vulnerability in Variable endpoint |
| - [AIRFLOW-1497] Reset hidden fields when changing connection type |
| - [AIRFLOW-1619] Add poll_sleep parameter to GCP dataflow operator |
| - [AIRFLOW-XXX] Remove landscape.io config |
| - [AIRFLOW-XXX] Remove non working service badges |
| - [AIRFLOW-1177] Fix Variable.setdefault w/existing JSON |
| - [AIRFLOW-1600] Fix exception handling in get_fernet |
| - [AIRFLOW-1614] Replace inspect.stack() with sys._getframe() |
| - [AIRFLOW-1519] Add server side paging in DAGs list |
| - [AIRFLOW-1309] Allow hive_to_druid to take tblproperties |
| - [AIRFLOW-1613] Make MySqlToGoogleCloudStorageOperator compatible with python3 |
| - [AIRFLOW-1603] add PAYMILL to companies list |
| - [AIRFLOW-1609] Fix gitignore to ignore all venvs |
| - [AIRFLOW-1601] Add configurable task cleanup time |
| |
| Airflow 1.9.0, 2018-01-02 |
| ------------------------- |
| |
| - [AIRFLOW-1525] Fix minor LICENSE and NOTICE issues |
| - [AIRFLOW-XXX] Bump version to 1.9.0 |
| - [AIRFLOW-1897][AIRFLOW-1873] Task Logs for running instance not visible in WebUI |
| - [AIRFLOW-XXX] Make sure session is committed |
| - [AIRFLOW-1896] FIX bleach <> html5lib incompatibility |
| - [AIRFLOW-XXX] Fix log handler test |
| - [AIRFLOW-1873] Set TI.try_number to right value depending TI state |
| - [AIRFLOW-1554] Fix wrong DagFileProcessor termination method call |
| - [AIRFLOW-1872] Set context for all handlers including parents |
| - [AIRFLOW-XXX] Add dask lock files to excludes |
| - [AIRFLOW-1839] Fix more bugs in S3Hook boto -> boto3 migration |
| - [AIRFLOW-1795] Correctly call S3Hook after migration to boto3 |
| - [AIRFLOW-1813] Bug SSH Operator empty buffer |
| - [AIRFLOW-1794] Remove uses of Exception.message for Python 3 |
| - [AIRFLOW-1799] Fix logging line which raises errors |
| - [AIRFLOW-1102] Upgrade gunicorn >=19.4.0 |
| - [AIRFLOW-1756] Fix S3TaskHandler to work with Boto3-based S3Hook |
| - [AIRFLOW-1797] S3Hook.load_string did not work on Python3 |
| - [AIRFLOW-1792] Missing intervals DruidOperator |
| - [AIRFLOW-1789][AIRFLOW-1712] Log SSHOperator stderr to log.warning |
| - [AIRFLOW-1669] Fix Docker and pin Moto to 1.1.19 |
| - [AIRFLOW-71] Add support for private Docker images |
| - [AIRFLOW-1779] Add keepalive packets to ssh hook |
| - [AIRFLOW-XXX] Give a clue what the 'ds' variable is |
| - [AIRFLOW-XXX] Correct typos in the faq docs page |
| - [AIRFLOW-1571] Add AWS Lambda Hook |
| - [AIRFLOW-1675] Fix docstrings for API docs |
| - [AIRFLOW-1712][AIRFLOW-756][AIRFLOW-751] Log SSHOperator output |
| - [AIRFLOW-1776] Capture stdout and stderr for logging |
| - [AIRFLOW-1765] Make experimental API securable without needing Kerberos. |
| - [AIRFLOW-1764] The web interface should not use the experimental API |
| - [AIRFLOW-1634] Adds task_concurrency feature |
| - [AIRFLOW-1018] Make processor use logging framework |
| - [AIRFLOW-1695] Add RedshiftHook using boto3 |
| - [AIRFLOW-1706] Fix query error for MSSQL backend |
| - [AIRFLOW-1711] Use ldap3 dict for group membership |
| - [AIRFLOW-1757] Add missing options to SparkSubmitOperator |
| - [AIRFLOW-1734][Airflow 1734] Sqoop hook/operator enhancements |
| - [AIRFLOW-1731] Set pythonpath for logging |
| - [AIRFLOW-1641] Handle executor events in the scheduler |
| - [AIRFLOW-1744] Make sure max_tries can be set |
| - [AIRFLOW-1330] Add conn_type argument to CLI when adding connection |
| - [AIRFLOW-926] Fix JDBC Hook |
| - [AIRFLOW-1520] Boto3 S3Hook, S3Log |
| - [AIRFLOW-XXX] Fix DateTime in Tree View |
| - [AIRFLOW-1432] Charts label for Y axis not visible |
| - [AIRFLOW-1743] Verify ldap filters correctly |
| - [AIRFLOW-1745] Restore default signal disposition |
| - [AIRFLOW-1741] Correctly hide second chart on task duration page |
| - [AIRFLOW-1726] Add copy_expert psycopg2 method to PostgresHook |
| - [AIRFLOW-1698] Remove SCHEDULER_RUNS env var in systemd |
| - [AIRFLOW-1694] Stop using itertools.izip |
| - [AIRFLOW-1692] Change test_views filename to support Windows |
| - [AIRFLOW-1722] Fix typo in scheduler autorestart output filename |
| - [AIRFLOW-1691] Add better Google Cloud logging documentation |
| - [AIRFLOW-1690] Add detail to gcs error messages |
| - [AIRFLOW-1682] Make S3TaskHandler write to S3 on close |
| - [AIRFLOW-1676] Make GCSTaskHandler write to GCS on close |
| - [AIRFLOW-1635] Allow creating GCP connection without requiring a JSON file |
| - [AIRFLOW-1323] Made Dataproc operator parameter names consistent |
| - [AIRFLOW-1590] fix unused module and variable |
| - [AIRFLOW-988] Fix repeating SLA miss callbacks |
| - [AIRFLOW-1611] Customize logging |
| - [AIRFLOW-1668] Expose keepalives_idle for Postgres connections |
| - [AIRFLOW-1658] Kill Druid task on timeout |
| - [AIRFLOW-1669][AIRFLOW-1368] Fix Docker import |
| - [AIRFLOW-1560] Add AWS DynamoDB hook and operator for inserting batch items |
| - [AIRFLOW-1654] Show tooltips for link icons in DAGs view |
| - [AIRFLOW-1660] Change webpage width to full-width |
| - [AIRFLOW-1664] write file as binary instead of str |
| - [AIRFLOW-1659] Fix invalid obj attribute bug in file_task_handler.py |
| - [AIRFLOW-1650] Fix custom celery config loading |
| - [AIRFLOW-1647] Fix Spark-sql hook |
| - [AIRFLOW-1587] Fix CeleryExecutor import error |
| - [AIRFLOW-1636] Add AWS and EMR connection type |
| - [AIRFLOW-1527] Refactor celery config |
| - [AIRFLOW-1639] Fix Fernet error handling |
| - [AIRFLOW-1628] Fix docstring of sqlsensor |
| - [AIRFLOW-1331] add SparkSubmitOperator option |
| - [AIRFLOW-1627] Only query pool in SubDAG init when necessary |
| - [AIRFLOW-1629] Make extra a textarea in edit connections form |
| - [AIRFLOW-1621] Add tests for server side paging |
| - [AIRFLOW-1519] Add server side paging in DAGs list |
| - [AIRFLOW-289] Make Airflow timezone independent |
| - [AIRFLOW-1356] Add `--celery_hostname` to `airflow worker` |
| - [AIRFLOW-1591] Avoid attribute error when rendering logging filename |
| - [AIRFLOW-1031] Replace hard-code to DagRun.ID_PREFIX |
| - [AIRFLOW-1604] Rename logger to log |
| - [AIRFLOW-1512] Add PythonVirtualenvOperator |
| - [AIRFLOW-1617] Fix XSS vulnerability in Variable endpoint |
| - [AIRFLOW-1497] Reset hidden fields when changing connection type |
| - [AIRFLOW-1177] Fix Variable.setdefault w/existing JSON |
| - [AIRFLOW-1600] Fix exception handling in get_fernet |
| - [AIRFLOW-1614] Replace inspect.stack() with sys._getframe() |
| - [AIRFLOW-1613] Make MySqlToGoogleCloudStorageOperator compatible with python3 |
| - [AIRFLOW-1609] Fix gitignore to ignore all venvs |
| - [AIRFLOW-1601] Add configurable task cleanup time |
| - [AIRFLOW-XXX] Bumping airflow 1.9.0alpha0 version |
| - [AIRFLOW-1608] Handle pending job state in GCP Dataflow hook |
| - [AIRFLOW-1606] Use non static DAG.sync_to_db |
| - [AIRFLOW-1606][Airflow-1606][AIRFLOW-1605][AIRFLOW-160] DAG.sync_to_db is now a normal method |
| - [AIRFLOW-1602] LoggingMixin in DAG class |
| - [AIRFLOW-1593] expose load_string in WasbHook |
| - [AIRFLOW-1597] Add GameWisp as Airflow user |
| - [AIRFLOW-1594] Don't install test packages into Python root.[] |
| - [AIRFLOW-1582] Improve logging within Airflow |
| - [AIRFLOW-1476] add INSTALL instruction for source releases |
| - [AIRFLOW-XXX] Save username and password in airflow-pr |
| - [AIRFLOW-1522] Increase text size for var field in variables for MySQL |
| - [AIRFLOW-950] Missing AWS integrations on documentation::integrations |
| - [AIRFLOW-XXX] 1.8.2 release notes |
| - [AIRFLOW-1573] Remove `thrift < 0.10.0` requirement |
| - [AIRFLOW-1584] Remove insecure /headers endpoint |
| - [AIRFLOW-1586] Add mapping for date type to mysql_to_gcs operator |
| - [AIRFLOW-1579] Adds support for jagged rows in Bigquery hook for BQ load jobs |
| - [AIRFLOW-1577] Add token support to DatabricksHook |
| - [AIRFLOW-1580] Error in string formatting |
| - [AIRFLOW-1567] Updated docs for Google ML Engine operators/hooks |
| - [AIRFLOW-1574] add 'to' attribute to templated vars of email operator |
| - [AIRFLOW-1572] add carbonite to company list |
| - [AIRFLOW-1568] Fix typo in BigQueryHook |
| - [AIRFLOW-1493][AIRFLOW-XXXX][WIP] fixed dumb thing |
| - [AIRFLOW-1567][Airflow-1567] Renamed cloudml hook and operator to mlengine |
| - [AIRFLOW-1568] Add datastore export/import operators |
| - [AIRFLOW-1564] Use Jinja2 to render logging filename |
| - [AIRFLOW-1562] Spark-sql logging contains deadlock |
| - [AIRFLOW-1556][Airflow 1556] Add support for SQL parameters in BigQueryBaseCursor |
| - [AIRFLOW-108] Add CreditCards.com to companies list |
| - [AIRFLOW-1541] Add channel to template fields of slack_operator |
| - [AIRFLOW-1535] Add service account/scopes in dataproc |
| - [AIRFLOW-1384] Add to README.md CaDC/ARGO |
| - [AIRFLOW-1546] add Zymergen 80to org list in README |
| - [AIRFLOW-1545] Add Nextdoor to companies list |
| - [AIRFLOW-1544] Add DataFox to companies list |
| - [AIRFLOW-1529] Add logic supporting quoted newlines in Google BigQuery load jobs |
| - [AIRFLOW-1521] Fix template rendering for BigqueryTableDeleteOperator |
| - [AIRFLOW-1324] Generalize Druid operator and hook |
| - [AIRFLOW-1516] Fix error handling getting fernet |
| - [AIRFLOW-1420][AIRFLOW-1473] Fix deadlock check |
| - [AIRFLOW-1495] Fix migration on index on job_id |
| - [AIRFLOW-1483] Making page size consistent in list |
| - [AIRFLOW-1495] Add TaskInstance index on job_id |
| - [AIRFLOW-855] Replace PickleType with LargeBinary in XCom |
| - [AIRFLOW-1505] Document when Jinja substitution occurs |
| - [AIRFLOW-1504] Log dataproc cluster name |
| - [AIRFLOW-1239] Fix unicode error for logs in base_task_runner |
| - [AIRFLOW-1280] Fix Gantt chart height |
| - [AIRFLOW-1507] Template parameters in file_to_gcs operator |
| - [AIRFLOW-1452] workaround lock on method |
| - [AIRFLOW-1385] Make Airflow task logging configurable |
| - [AIRFLOW-940] Handle error on variable decrypt |
| - [AIRFLOW-1492] Add gauge for task successes/failures |
| - [AIRFLOW-1443] Update Airflow configuration documentation |
| - [AIRFLOW-1486] Unexpected S3 writing log error |
| - [AIRFLOW-1487] Added links to all companies officially using Airflow |
| - [AIRFLOW-1489] Fix typo in BigQueryCheckOperator |
| - [AIRFLOW-1349] Fix backfill to respect limits |
| - [AIRFLOW-1478] Chart owner column should be sortable |
| - [AIRFLOW-1397][AIRFLOW-1] No Last Run column data displayed in airflow UI 1.8.1 |
| - [AIRFLOW-1474] Add dag_id regex feature for `airflow clear` command |
| - [AIRFLOW-1445] Changing HivePartitionSensor UI color to lighter shade |
| - [AIRFLOW-1359] Use default_args in Cloud ML eval |
| - [AIRFLOW-1389] Support createDisposition in BigQueryOperator |
| - [AIRFLOW-1349] Refactor BackfillJob _execute |
| - [AIRFLOW-1459] Fixed broken integration .rst formatting |
| - [AIRFLOW-1448] Revert "Fix cli reading logfile in memory" |
| - [AIRFLOW-1398] Allow ExternalTaskSensor to wait on multiple runs of a task |
| - [AIRFLOW-1399] Fix cli reading logfile in memory |
| - [AIRFLOW-1442] Remove extra space from ignore_all_deps generated command |
| - [AIRFLOW-1438] Change batch size per query in scheduler |
| - [AIRFLOW-1439] Add max billing tier for the BQ Hook and Operator |
| - [AIRFLOW-1437] Modify BigQueryTableDeleteOperator |
| - [Airflow 1332] Split logs based on try number |
| - [AIRFLOW-1385] Create abstraction for Airflow task logging |
| - [AIRFLOW-756][AIRFLOW-751] Replace ssh hook, operator & sftp operator with paramiko based |
| - [AIRFLOW-1393][[AIRFLOW-1393] Enable Py3 tests in contrib/spark_submit_hook[ |
| - [AIRFLOW-1345] Dont expire TIs on each scheduler loop |
| - [AIRFLOW-1059] Reset orphaned tasks in batch for scheduler |
| - [AIRFLOW-1255] Fix SparkSubmitHook output deadlock |
| - [AIRFLOW-1359] Add Google CloudML utils for model evaluation |
| - [AIRFLOW-1247] Fix ignore all dependencies argument ignored |
| - [AIRFLOW-1401] Standardize cloud ml operator arguments |
| - [AIRFLOW-1394] Add quote_character param to GCS hook and operator |
| - [AIRFLOW-1402] Cleanup SafeConfigParser DeprecationWarning |
| - [AIRFLOW-1326][[AIRFLOW-1326][AIRFLOW-1184] Don't split argument array -- it's already an array.[ |
| - [AIRFLOW-1384] Add ARGO/CaDC as a Airflow user |
| - [AIRFLOW-1357] Fix scheduler zip file support |
| - [AIRFLOW-1382] Add working dir option to DockerOperator |
| - [AIRFLOW-1388] Add Cloud ML Engine operators to integration doc |
| - [AIRFLOW-1387] Add unicode string prefix |
| - [AIRFLOW-1366] Add max_tries to task instance |
| - [AIRFLOW-1300] Enable table creation with TBLPROPERTIES |
| - [AIRFLOW-1271] Add Google CloudML Training Operator |
| - [AIRFLOW-300] Add Google Pubsub hook and operator |
| - [AIRFLOW-1343] Fix dataproc label format |
| - [AIRFLOW-1367] Pass Content-ID To reference inline images in an email, we need to be able to add <img src="cid:{}"/> to the HTML. However currently the Content-ID (cid) is not passed, so we need to add it |
| - [AIRFLOW-1265] Fix celery executor parsing CELERY_SSL_ACTIVE |
| - [AIRFLOW-1272] Google Cloud ML Batch Prediction Operator |
| - [AIRFLOW-1352][AIRFLOW-1335] Revert MemoryHandler change ()[] |
| - [AIRFLOW-1350] Add query_uri param to Hive/SparkSQL DataProc operator |
| - [AIRFLOW-1334] Check if tasks are backfill on scheduler in a join |
| - [AIRFLOW-1343] Add Airflow default label to the dataproc operator |
| - [AIRFLOW-1273] Add Google Cloud ML version and model operators |
| - [AIRFLOW-1273]AIRFLOW-1273] Add Google Cloud ML version and model operators |
| - [AIRFLOW-1321] Fix hidden field key to ignore case |
| - [AIRFLOW-1337] Make log_format key names lowercase |
| - [AIRFLOW-1338][AIRFLOW-782] Add GCP dataflow hook runner change to UPDATING.md |
| - [AIRFLOW-801] Remove outdated docstring on BaseOperator |
| - [AIRFLOW-1344] Fix text encoding bug when reading logs for Python 3.5 |
| - [AIRFLOW-1338] Fix incompatible GCP dataflow hook |
| - [AIRFLOW-1333] Enable copy function for Google Cloud Storage Hook |
| - [AIRFLOW-1337] Allow log format customization via airflow.cfg |
| - [AIRFLOW-1320] Update LetsBonus users in README |
| - [AIRFLOW-1335] Use MemoryHandler for buffered logging |
| - [AIRFLOW-1339] Add Drivy to the list of users |
| - [AIRFLOW-1275] Put 'airflow pool' into API |
| - [AIRFLOW-1296] Propagate SKIPPED to all downstream tasks |
| - [AIRFLOW-1317] Fix minor issues in API reference |
| - [AIRFLOW-1308] Disable nanny usage for Dask |
| - [AIRFLOW-1172] Support nth weekday of the month cron expression |
| - [AIRFLOW-936] Add clear/mark success for DAG in the UI |
| - [AIRFLOW-1294] Backfills can loose tasks to execute |
| - [AIRFLOW-1299] Support imageVersion in Google Dataproc cluster |
| - [AIRFLOW-1291] Update NOTICE and LICENSE files to match ASF requirements |
| - [AIRFLOW-1301] Add New Relic to list of companies |
| - [AIRFLOW-1289] Removes restriction on number of scheduler threads |
| - [AIRFLOW-1024] Ignore celery executor errors (#49) |
| - [AIRFLOW-1265] Fix exception while loading celery configurations |
| - [AIRFLOW-1290] set docs author to 'Apache Airflow' |
| - [AIRFLOW-1242] Allowing project_id to have a colon in it. |
| - [AIRFLOW-1282] Fix known event column sorting |
| - [AIRFLOW-1166] Speed up _change_state_for_tis_without_dagrun |
| - [AIRFLOW-1208] Speed-up cli tests |
| - [AIRFLOW-1192] Some enhancements to qubole_operator |
| - [AIRFLOW-1281] Sort variables by key field by default |
| - [AIRFLOW-1277] Forbid KE creation with empty fields |
| - [AIRFLOW-1276] Forbid event creation with end_data earlier than start_date |
| - [AIRFLOW-1263] Dynamic height for charts |
| - [AIRFLOW-1266] Increase width of gantt y axis |
| - [AIRFLOW-1244] Forbid creation of a pool with empty name |
| - [AIRFLOW-1274][HTTPSENSOR] Rename parameter params to data |
| - [AIRFLOW-654] Add SSL Config Option for CeleryExecutor w/ RabbitMQ - Add BROKER_USE_SSL config to give option to send AMQP messages over SSL - Can be set using usual Airflow options (e.g. airflow.cfg, env vars, etc.) |
| - [AIRFLOW-1256] Add United Airlines to readme |
| - [AIRFLOW-1251] Add eRevalue to Airflow users |
| - [AIRFLOW-908] Print hostname at the start of cli run |
| - [AIRFLOW-1237] Fix IN-predicate sqlalchemy warning |
| - [AIRFLOW-1243] DAGs table has no default entries to show |
| - [AIRFLOW-1245] Fix random failure in test_trigger_dag_for_date |
| - [AIRFLOW-1248] Fix wrong conf name for worker timeout |
| - [AIRFLOW-1197] : SparkSubmitHook on_kill error |
| - [AIRFLOW-1191] : SparkSubmitHook custom cmd |
| - [AIRFLOW-1234] Cover utils.operator_helpers with UTs |
| - [AIRFLOW-1217] Enable Sqoop logging |
| - [AIRFLOW-645] Support HTTPS connections in HttpHook |
| - [AIRFLOW-1231] Use flask_wtf.CSRFProtect |
| - [AIRFLOW-1232] Remove deprecated readfp warning |
| - [AIRFLOW-1233] Cover utils.json with unit tests |
| - [AIRFLOW-1227] Remove empty column on the Logs view |
| - [AIRFLOW-1226] Remove empty column on the Jobs view |
| - [AIRFLOW-1221] Fix templating bug with DatabricksSubmitRunOperator |
| - [AIRFLOW-1210] Enable DbApiHook unit tests |
| - [AIRFLOW-1199] Fix create modal |
| - [AIRFLOW-1200] Forbid creation of a variable with an empty key |
| - [AIRFLOW-1207] Enable utils.helpers unit tests |
| - [AIRFLOW-1213] Add hcatalog parameters to sqoop |
| - [AIRFLOW-1201] Update deprecated 'nose-parameterized' |
| - [AIRFLOW-1186] Sort dag.get_task_instances by execution_date |
| - [AIRFLOW-1203] Pin Google API client version to fix OAuth issue |
| - [AIRFLOW-1145] Fix closest_date_partition function with before set to True If we're looking for the closest date before, we should take the latest date in the list of date before. |
| - [AIRFLOW-1180] Fix flask-wtf version for test_csrf_rejection |
| - [AIRFLOW-993] Update date inference logic |
| - [AIRFLOW-1170] DbApiHook insert_rows inserts parameters separately |
| - [AIRFLOW-1041] Do not shadow xcom_push method[] |
| - [AIRFLOW-860][AIRFLOW-935] Fix plugin executor import cycle and executor selection |
| - [AIRFLOW-1189] Fix get a DataFrame using BigQueryHook failing |
| - [AIRFLOW-1184] SparkSubmitHook does not split args |
| - [AIRFLOW-1182] SparkSubmitOperator template field |
| - [AIRFLOW-823] Allow specifying execution date in task_info API |
| - [AIRFLOW-1175] Add Pronto Tools to Airflow user list |
| - [AIRFLOW-1150] Fix scripts execution in sparksql hook[] |
| - [AIRFLOW-1141] remove crawl_for_tasks |
| - [AIRFLOW-1193] Add Checkr to company using Airflow |
| - [AIRFLOW-1168] Add closing() to all connections and cursors |
| - [AIRFLOW-1188] Add max_bad_records param to GoogleCloudStorageToBigQueryOperator |
| - [AIRFLOW-1187][AIRFLOW-1185] Fix PyPi package names in documents |
| - [AIRFLOW-1185] Fix PyPi URL in templates |
| - [AIRFLOW-XXX] Updating CHANGELOG, README, and UPDATING after 1.8.1 release |
| - [AIRFLOW-1181] Add delete and list functionality to gcs_hook |
| - [AIRFLOW-1179] Fix Pandas 0.2x breaking Google BigQuery change |
| - [AIRFLOW-1167] Support microseconds in FTPHook modification time |
| - [AIRFLOW-1173] Add Robinhood to who uses Airflow |
| - [AIRFLOW-945][AIRFLOW-941] Remove psycopg2 connection workaround |
| - [AIRFLOW-1140] DatabricksSubmitRunOperator should template the "json" field. |
| - [AIRFLOW-1160] Update Spark parameters for Mesos |
| - [AIRFLOW 1149][AIRFLOW-1149] Allow for custom filters in Jinja2 templates |
| - [AIRFLOW-1036] Randomize exponential backoff |
| - [AIRFLOW-1155] Add Tails.com to community |
| - [AIRFLOW-1142] Do not reset orphaned state for backfills |
| - [AIRFLOW-492] Make sure stat updates cannot fail a task |
| - [AIRFLOW-1119] Fix unload query so headers are on first row[] |
| - [AIRFLOW-1089] Add Spark application arguments |
| - [AIRFLOW-1125] Document encrypted connections |
| - [AIRFLOW-1122] Increase stroke width in UI |
| - [AIRFLOW-1138] Add missing licenses to files in scripts directory |
| - [AIRFLOW-11-38][AIRFLOW-1136] Capture invalid arguments for Sqoop |
| - [AIRFLOW-1127] Move license notices to LICENSE |
| - [AIRFLOW-1118] Add evo.company to Airflow users |
| - [AIRFLOW-1121][AIRFLOW-1004] Fix `airflow webserver --pid` to write out pid file |
| - [AIRFLOW-1124] Do not set all tasks to scheduled in backfill |
| - [AIRFLOW-1120] Update version view to include Apache prefix |
| - [AIRFLOW-1091] Add script that can compare Jira target against merges |
| - [AIRFLOW-1107] Add support for ftps non-default port |
| - [AIRFLOW-1000] Rebrand distribution to Apache Airflow |
| - [AIRFLOW-1094] Run unit tests under contrib in Travis |
| - [AIRFLOW-1112] Log which pool when pool is full in scheduler |
| - [AIRFLOW-1106] Add Groupalia/Letsbonus to the ReadMe |
| - [AIRFLOW-1109] Use kill signal to kill processes and log results |
| - [AIRFLOW-1074] Don't count queued tasks for concurrency limits |
| - [AIRFLOW-1095] Make ldap_auth memberOf come from configuration |
| - [AIRFLOW-1090] Add HBO |
| - [AIRFLOW-1035] Use binary exponential backoff |
| - [AIRFLOW-1081] Improve performance of duration chart |
| - [AIRFLOW-1078] Fix latest_runs endpoint for old flask versions |
| - [AIRFLOW-1085] Enhance the SparkSubmitOperator |
| - [AIRFLOW-1050] Do not count up_for_retry as not ready |
| - [AIRFLOW-1028] Databricks Operator for Airflow |
| - [AIRFLOW-1075] Security docs cleanup |
| - [AIRFLOW-1033][AIFRLOW-1033] Fix ti_deps for no schedule dags |
| - [AIRFLOW-1016] Allow HTTP HEAD request method on HTTPSensor |
| - [AIRFLOW-970] Load latest_runs on homepage async |
| - [AIRFLOW-111] Include queued tasks in scheduler concurrency check |
| - [AIRFLOW-1001] Fix landing times if there is no following schedule |
| - [AIRFLOW-1065] Add functionality for Azure Blob Storage over wasb:// |
| - [AIRFLOW-947] Improve exceptions for unavailable Presto cluster |
| - [AIRFLOW-1067] use example.com in examples |
| - [AIRFLOW-1064] Change default sort to job_id for TaskInstanceModelView |
| - [AIRFLOW-1030][AIRFLOW-1] Fix hook import for HttpSensor |
| - [AIRFLOW-1051] Add a test for resetdb to CliTests |
| - [AIRFLOW-1004][AIRFLOW-276] Fix `airflow webserver -D` to run in background |
| - [AIRFLOW-1062] Fix DagRun#find to return correct result |
| - [AIRFLOW-1011] Fix bug in BackfillJob._execute() for SubDAGs |
| - [AIRFLOW-1038] Specify celery serialization options explicitly |
| - [AIRFLOW-1054] Fix broken import in test_dag |
| - [AIRFLOW-1007] Use Jinja sandbox for chart_data endpoint |
| - [AIRFLOW-719] Fix race condition in ShortCircuit, Branch and LatestOnly |
| - [AIRFLOW-1043] Fix doc strings of operators |
| - [AIRFLOW-840] Make ticket renewer python3 compatible |
| - [AIRFLOW-985] Extend the sqoop operator and hook |
| - [AIRFLOW-1034] Make it possible to connect to S3 in sigv4 regions |
| - [AIRFLOW-1045] Make log level configurable via airflow.cfg |
| - [AIRFLOW-1047] Sanitize strings passed to Markup |
| - [AIRFLOW-1040] Fix some small typos in comments and docstrings |
| - [AIRFLOW-1017] get_task_instance should not throw exception when no TI |
| - [AIRFLOW-1006] Add config_templates to MANIFEST |
| - [AIRFLOW-999] Add support for Redis database |
| - [AIRFLOW-1009] Remove SQLOperator from Concepts page |
| - [AIRFLOW-1006] Move config templates to separate files |
| - [AIRFLOW-1005] Improve Airflow startup time |
| - [AIRFLOW-1010] Add convenience script for signing releases |
| - [AIRFLOW-995] Remove reference to actual Airflow issue |
| - [AIRFLOW-681] homepage doc link should pointing to apache repo not airbnb repo |
| - [AIRFLOW-705][AIRFLOW-706] Fix run_command bugs |
| - [AIRFLOW-990] Fix Py27 unicode logging in DockerOperator |
| - [AIRFLOW-963] Fix non-rendered code examples |
| - [AIRFLOW-969] Catch bad python_callable argument |
| - [AIRFLOW-984] Enable subclassing of SubDagOperator |
| - [AIRFLOW-997] Update setup.cfg to point to Apache |
| - [AIRFLOW-994] Add MiNODES to the official Airflow user list |
| - [AIRFLOW-995][AIRFLOW-1] Update GitHub PR Template |
| - [AIRFLOW-989] Do not mark dag run successful if unfinished tasks |
| - [AIRFLOW-903] New configuration setting for the default dag view |
| - [AIRFLOW-979] Add GovTech GDS |
| - [AIRFLOW-933] Replace eval with literal_eval to prevent RCE |
| - [AIRFLOW-974] Fix mkdirs race condition |
| - [AIRFLOW-917] Fix formatting of error message |
| - [AIRFLOW-770] Refactor BaseHook so env vars are always read |
| - [AIRFLOW-900] Double trigger should not kill original task instance |
| - [AIRFLOW-900] Fixes bugs in LocalTaskJob for double run protection |
| - [AIRFLOW-932][AIRFLOW-932][AIRFLOW-921][AIRFLOW-910] Do not mark tasks removed when backfilling |
| - [AIRFLOW-961] run onkill when SIGTERMed |
| - [AIRFLOW-910] Use parallel task execution for backfills |
| - [AIRFLOW-967] Wrap strings in native for py2 ldap compatibility |
| - [AIRFLOW-958] Improve tooltip readability |
| - AIRFLOW-959 Cleanup and reorganize .gitignore |
| - AIRFLOW-960 Add .editorconfig file |
| - [AIRFLOW-931] Do not set QUEUED in TaskInstances |
| - [AIRFLOW-956] Get docs working on readthedocs.org |
| - [AIRFLOW-954] Fix configparser ImportError |
| - [AIRFLOW-941] Use defined parameters for psycopg2 |
| - [AIRFLOW-943] Update Digital First Media in users list |
| - [AIRFLOW-942] Add mytaxi to Airflow users |
| - [AIRFLOW-939] add .swp to gitignore |
| - [AIRFLOW-719] Prevent DAGs from ending prematurely |
| - [AIRFLOW-938] Use test for True in task_stats queries |
| - [AIRFLOW-937] Improve performance of task_stats |
| - [AIRFLOW-933] use ast.literal_eval rather eval because ast.literal_eval does not execute input. |
| - [AIRFLOW-925] Revert airflow.hooks change that cherry-pick picked |
| - [AIRFLOW-919] Running tasks with no start date should not break a DAGs UI |
| - [AIRFLOW-802][AIRFLOW-1] Add spark-submit operator/hook |
| - [AIRFLOW-725] Use keyring to store credentials for JIRA |
| - [AIRFLOW-916] Remove deprecated readfp function |
| - [AIRFLOW-911] Add coloring and timing to tests |
| - [AIRFLOW-906] Update Code icon from lightning bolt to file |
| - [AIRFLOW-897] Prevent dagruns from failing with unfinished tasks |
| - [AIRFLOW-896] Remove unicode to 8-bit conversion in BigQueryOperator |
| - [AIRFLOW-899] Tasks in SCHEDULED state should be white in the UI instead of black |
| - [AIRFLOW-895] Address Apache release incompliancies |
| - [AIRFLOW-893][AIRFLOW-510] Fix crashing webservers when a dagrun has no start date |
| - [AIRFLOW-880] Make webserver serve logs in a sane way for remote logs |
| - [AIRFLOW-889] Fix minor error in the docstrings for BaseOperator |
| - [AIRFLOW-809][AIRFLOW-1] Use __eq__ ColumnOperator When Testing Booleans |
| - [AIRFLOW-875] Add template to HttpSensor params |
| - [AIRFLOW-866] Add FTPSensor |
| - [AIRFLOW-881] Check if SubDagOperator is in DAG context manager |
| - [AIRFLOW-885] Add change.org to the users list |
| - [AIRFLOW-836] Use POST and CSRF for state changing endpoints |
| - [AIRFLOW-862] Fix Unit Tests for DaskExecutor |
| - [AIRFLOW-887] Support future v0.16 |
| - [AIRFLOW-886] Pass result to post_execute() hook |
| - [AIRFLOW-871] change logging.warn() into warning() |
| - [AIRFLOW-882] Remove unnecessary dag>>op assignment in docs |
| - [AIRFLOW-861] Make pickle_info endpoint be login_required |
| - [AIRFLOW-869] Refactor mark success functionality |
| - [AIRFLOW-877] Remove .sql template extension from GCS download operator |
| - [AIRFLOW-826] Add Zendesk hook |
| - [AIRFLOW-842] Do not query the DB with an empty IN clause |
| - [AIRFLOW-834] Change raise StopIteration into return |
| - [AIRFLOW-832] Let debug server run without SSL |
| - [AIRFLOW-862] Add DaskExecutor |
| - [AIRFLOW-858] Configurable database name for DB operators |
| - [AIRFLOW-863] Example DAGs should have recent start dates |
| - [AIRFLOW-853] Use utf8 encoding for stdout line decode |
| - [AIRFLOW-857] Use library assert statements instead of conditionals |
| - [AIRFLOW-856] Make sure execution date is set for local client |
| - [AIRFLOW-854] Add OKI as Airflow user |
| - [AIRFLOW-830][AIRFLOW-829][AIRFLOW-88] Reduce Travis log verbosity |
| - [AIRFLOW-814] Fix Presto*CheckOperator.__init__ |
| - [AIRFLOW-793] Enable compressed loading in S3ToHiveTransfer |
| - [AIRFLOW-844] Fix cgroups directory creation |
| - [AIRFLOW-831] Restore import to fix broken tests |
| - [AIRFLOW-794] Access DAGS_FOLDER and SQL_ALCHEMY_CONN exclusively from settings |
| - [AIRFLOW-694] Fix config behaviour for empty envvar |
| - [AIRFLOW-365] Set dag.fileloc explicitly and use for Code view |
| - [AIRFLOW-781] Allow DataFlowOperators to accept jobs stored in GCS |
| |
| Airflow 1.8.2, 2017-09-04 |
| ------------------------- |
| |
| - [AIRFLOW-809][AIRFLOW-1] Use __eq__ ColumnOperator When Testing Booleans |
| - [AIRFLOW-1296] Propagate SKIPPED to all downstream tasks |
| - Re-enable caching for hadoop components |
| - Pin Hive and Hadoop to a specific version and create writable warehouse dir |
| - [AIRFLOW-1308] Disable nanny usage for Dask |
| - Updating CHANGELOG for 1.8.2rc1 |
| - [AIRFLOW-1294] Backfills can loose tasks to execute |
| - [AIRFLOW-1291] Update NOTICE and LICENSE files to match ASF requirements |
| - [AIRFLOW-XXX] Set version to 1.8.2rc1 |
| - [AIRFLOW-1160] Update Spark parameters for Mesos |
| - [AIRFLOW 1149][AIRFLOW-1149] Allow for custom filters in Jinja2 templates |
| - [AIRFLOW-1119] Fix unload query so headers are on first row[] |
| - [AIRFLOW-1089] Add Spark application arguments |
| - [AIRFLOW-1078] Fix latest_runs endpoint for old flask versions |
| - [AIRFLOW-1074] Don't count queued tasks for concurrency limits |
| - [AIRFLOW-1064] Change default sort to job_id for TaskInstanceModelView |
| - [AIRFLOW-1038] Specify celery serialization options explicitly |
| - [AIRFLOW-1036] Randomize exponential backoff |
| - [AIRFLOW-993] Update date inference logic |
| - [AIRFLOW-1167] Support microseconds in FTPHook modification time |
| - [AIRFLOW-1179] Fix pandas 0.2x breaking Google BigQuery change |
| - [AIRFLOW-1263] Dynamic height for charts |
| - [AIRFLOW-1266] Increase width of gantt y axis |
| - [AIRFLOW-1290] set docs author to 'Apache Airflow' |
| - [AIRFLOW-1282] Fix known event column sorting |
| - [AIRFLOW-1166] Speed up _change_state_for_tis_without_dagrun |
| - [AIRFLOW-1192] Some enhancements to qubole_operator |
| - [AIRFLOW-1281] Sort variables by key field by default |
| - [AIRFLOW-1244] Forbid creation of a pool with empty name |
| - [AIRFLOW-1243] DAGs table has no default entries to show |
| - [AIRFLOW-1227] Remove empty column on the Logs view |
| - [AIRFLOW-1226] Remove empty column on the Jobs view |
| - [AIRFLOW-1199] Fix create modal |
| - [AIRFLOW-1200] Forbid creation of a variable with an empty key |
| - [AIRFLOW-1186] Sort dag.get_task_instances by execution_date |
| - [AIRFLOW-1145] Fix closest_date_partition function with before set to True If we're looking for the closest date before, we should take the latest date in the list of date before. |
| - [AIRFLOW-1180] Fix flask-wtf version for test_csrf_rejection |
| - [AIRFLOW-1170] DbApiHook insert_rows inserts parameters separately |
| - [AIRFLOW-1150] Fix scripts execution in sparksql hook[] |
| - [AIRFLOW-1168] Add closing() to all connections and cursors |
| - [AIRFLOW-XXX] Updating CHANGELOG, README, and UPDATING after 1.8.1 release |
| |
| Airflow 1.8.1, 2017-05-09 |
| ------------------------- |
| |
| - [AIRFLOW-1142] SubDAG Tasks Not Executed Even Though All Dependencies Met |
| - [AIRFLOW-1138] Add licenses to files in scripts directory |
| - [AIRFLOW-1127] Move license notices to LICENSE instead of NOTICE |
| - [AIRFLOW-1124] Do not set all task instances to scheduled on backfill |
| - [AIRFLOW-1120] Update version view to include Apache prefix |
| - [AIRFLOW-1062] DagRun#find returns wrong result if external_trigger=False is specified |
| - [AIRFLOW-1054] Fix broken import on test_dag |
| - [AIRFLOW-1050] Retries ignored - regression |
| - [AIRFLOW-1033] TypeError: can't compare datetime.datetime to None |
| - [AIRFLOW-1017] get_task_instance should return None instead of throw an exception for non-existent TIs |
| - [AIRFLOW-1011] Fix bug in BackfillJob._execute() for SubDAGs |
| - [AIRFLOW-1004] `airflow webserver -D` runs in foreground |
| - [AIRFLOW-1001] Landing Time shows "unsupported operand type(s) for -: 'datetime.datetime' and `NoneType`" on example_subdag_operator |
| - [AIRFLOW-1000] Rebrand to Apache Airflow instead of Airflow |
| - [AIRFLOW-989] Clear Task Regression |
| - [AIRFLOW-974] airflow.util.file mkdir has a race condition |
| - [AIRFLOW-906] Update Code icon from lightning bolt to file |
| - [AIRFLOW-858] Configurable database name for DB operators |
| - [AIRFLOW-853] ssh_execute_operator.py stdout decode default to ASCII |
| - [AIRFLOW-832] Fix debug server |
| - [AIRFLOW-817] Trigger dag fails when using CLI + API |
| - [AIRFLOW-816] Make sure to pull nvd3 from local resources |
| - [AIRFLOW-815] Add previous/next execution dates to available default variables. |
| - [AIRFLOW-813] Fix unterminated unit tests in tests.job (tests/job.py) |
| - [AIRFLOW-812] Scheduler job terminates when there is no dag file |
| - [AIRFLOW-806] UI should properly ignore DAG doc when it is None |
| - [AIRFLOW-794] Consistent access to DAGS_FOLDER and SQL_ALCHEMY_CONN |
| - [AIRFLOW-785] ImportError if cgroupspy is not installed |
| - [AIRFLOW-784] Cannot install with ``funcsigs`` > 1.0.0 |
| - [AIRFLOW-780] The UI no longer shows broken DAGs |
| - [AIRFLOW-777] dag_is_running is initialized to True instead of False |
| - [AIRFLOW-719] Skipped operations make DAG finish prematurely |
| - [AIRFLOW-694] Empty env vars do not overwrite non-empty config values |
| - [AIRFLOW-492] Insert into dag_stats table results into failed task while task itself succeeded |
| - [AIRFLOW-139] Executing VACUUM with PostgresOperator |
| - [AIRFLOW-111] DAG concurrency is not honored |
| - [AIRFLOW-88] Improve clarity Travis CI reports |
| |
| Airflow 1.8.0, 2017-03-12 |
| ------------------------- |
| |
| - [AIRFLOW-900] Double trigger should not kill original task instance |
| - [AIRFLOW-900] Fixes bugs in LocalTaskJob for double run protection |
| - [AIRFLOW-932] Do not mark tasks removed when backfilling |
| - [AIRFLOW-961] run onkill when SIGTERMed |
| - [AIRFLOW-910] Use parallel task execution for backfills |
| - [AIRFLOW-967] Wrap strings in native for py2 ldap compatibility |
| - [AIRFLOW-941] Use defined parameters for psycopg2 |
| - [AIRFLOW-719] Prevent DAGs from ending prematurely |
| - [AIRFLOW-938] Use test for True in task_stats queries |
| - [AIRFLOW-937] Improve performance of task_stats |
| - [AIRFLOW-933] use ast.literal_eval rather eval because ast.literal_eval does not execute input. |
| - [AIRFLOW-925] Revert airflow.hooks change that cherry-pick picked |
| - [AIRFLOW-919] Running tasks with no start date should not break a DAGs UI |
| - [AIRFLOW-802] Add spark-submit operator/hook |
| - [AIRFLOW-897] Prevent dagruns from failing with unfinished tasks |
| - [AIRFLOW-861] make pickle_info endpoint be login_required |
| - [AIRFLOW-853] use utf8 encoding for stdout line decode |
| - [AIRFLOW-856] Make sure execution date is set for local client |
| - [AIRFLOW-830][AIRFLOW-829][AIRFLOW-88] Reduce Travis log verbosity |
| - [AIRFLOW-831] Restore import to fix broken tests |
| - [AIRFLOW-794] Access DAGS_FOLDER and SQL_ALCHEMY_CONN exclusively from settings |
| - [AIRFLOW-694] Fix config behaviour for empty envvar |
| - [AIRFLOW-365] Set dag.fileloc explicitly and use for Code view |
| - [AIRFLOW-931] Do not set QUEUED in TaskInstances |
| - [AIRFLOW-899] Tasks in SCHEDULED state should be white in the UI instead of black |
| - [AIRFLOW-895] Address Apache release incompliancies |
| - [AIRFLOW-893][AIRFLOW-510] Fix crashing webservers when a dagrun has no start date |
| - [AIRFLOW-793] Enable compressed loading in S3ToHiveTransfer |
| - [AIRFLOW-863] Example DAGs should have recent start dates |
| - [AIRFLOW-869] Refactor mark success functionality |
| - [AIRFLOW-856] Make sure execution date is set for local client |
| - [AIRFLOW-814] Fix Presto*CheckOperator.__init__ |
| - [AIRFLOW-844] Fix cgroups directory creation |
| - [AIRFLOW-816] Use static nvd3 and d3 |
| - [AIRFLOW-821] Fix py3 compatibility |
| - [AIRFLOW-817] Check for None value of execution_date in endpoint |
| - [AIRFLOW-822] Close db before exception |
| - [AIRFLOW-815] Add prev/next execution dates to template variables |
| - [AIRFLOW-813] Fix unterminated unit tests in SchedulerJobTest |
| - [AIRFLOW-813] Fix unterminated scheduler unit tests |
| - [AIRFLOW-806] UI should properly ignore DAG doc when it is None |
| - [AIRFLOW-812] Fix the scheduler termination bug. |
| - [AIRFLOW-780] Fix dag import errors no longer working |
| - [AIRFLOW-783] Fix py3 incompatibility in BaseTaskRunner |
| - [AIRFLOW-810] Correct down_revision dag_id/state index creation |
| - [AIRFLOW-807] Improve scheduler performance for large DAGs |
| - [AIRFLOW-798] Check return_code before forcing termination |
| - [AIRFLOW-139] Let psycopg2 handle autocommit for PostgresHook |
| - [AIRFLOW-776] Add missing cgroups devel dependency |
| - [AIRFLOW-777] Fix expression to check if a DagRun is in running state |
| - [AIRFLOW-785] Don't import CgroupTaskRunner at global scope |
| - [AIRFLOW-784] Pin ``funcsigs`` to 1.0.0 |
| - [AIRFLOW-624] Fix setup.py to not import airflow.version as version |
| - [AIRFLOW-779] Task should fail with specific message when deleted |
| - [AIRFLOW-778] Fix completely broken MetastorePartitionSensor |
| - [AIRFLOW-739] Set pickle_info log to debug |
| - [AIRFLOW-771] Make S3 logs append instead of clobber |
| - [AIRFLOW-773] Fix flaky datetime addition in api test |
| - [AIRFLOW-219][AIRFLOW-398] Cgroups + impersonation |
| - [AIRFLOW-683] Add Jira hook, operator and sensor |
| - [AIRFLOW-762] Add Google DataProc delete operator |
| - [AIRFLOW-760] Update systemd config |
| - [AIRFLOW-759] Use previous dag_run to verify depend_on_past |
| - [AIRFLOW-757] Set child_process_log_directory default more sensible |
| - [AIRFLOW-692] Open XCom page to super-admins only |
| - [AIRFLOW-737] Fix HDFS Sensor directory. |
| - [AIRFLOW-747] Fix retry_delay not honoured |
| - [AIRFLOW-558] Add Support for dag.catchup=(True|False) Option |
| - [AIRFLOW-489] Allow specifying execution date in trigger_dag API |
| - [AIRFLOW-738] Commit deleted xcom items before insert |
| - [AIRFLOW-729] Add Google Cloud Dataproc cluster creation operator |
| - [AIRFLOW-728] Add Google BigQuery table sensor |
| - [AIRFLOW-741] Log to debug instead of info for app.py |
| - [AIRFLOW-731] Fix period bug for NamedHivePartitionSensor |
| - [AIRFLOW-740] Pin jinja2 to < 2.9.0 |
| - [AIRFLOW-663] Improve time units for task performance charts |
| - [AIRFLOW-665] Fix email attachments |
| - [AIRFLOW-734] Fix SMTP auth regression when not using user/pass |
| - [AIRFLOW-702] Fix LDAP Regex Bug |
| - [AIRFLOW-717] Add Cloud Storage updated sensor |
| - [AIRFLOW-695] Retries do not execute because dagrun is in FAILED state |
| - [AIRFLOW-673] Add operational metrics test for SchedulerJob |
| - [AIRFLOW-727] try_number is not increased |
| - [AIRFLOW-715] A more efficient HDFS Sensor: |
| - [AIRFLOW-716] Allow AVRO BigQuery load-job without schema |
| - [AIRFLOW-718] Allow the query URI for DataProc Pig |
| - Log needs to be part of try/catch block |
| - [AIRFLOW-721] Descendant process can disappear before termination |
| - [AIRFLOW-403] Bash operator's kill method leaves underlying processes running |
| - [AIRFLOW-657] Add AutoCommit Parameter for MSSQL |
| - [AIRFLOW-641] Improve pull request instructions |
| - [AIRFLOW-685] Add test for MySqlHook.bulk_load() |
| - [AIRFLOW-686] Match auth backend config section |
| - [AIRFLOW-691] Add SSH KeepAlive option to SSH_hook |
| - [AIRFLOW-709] Use same engine for migrations and reflection |
| - [AIRFLOW-700] Update to reference to web authentication documentation |
| - [AIRFLOW-649] Support non-sched DAGs in LatestOnlyOp |
| - [AIRFLOW-712] Fix AIRFLOW-667 to use proper HTTP error properties |
| - [AIRFLOW-710] Add OneFineStay as official user |
| - [AIRFLOW-703][AIRFLOW-1] Stop Xcom being cleared too early |
| - [AIRFLOW-679] Stop concurrent task instances from running |
| - [AIRFLOW-704][AIRFLOW-1] Fix invalid syntax in BQ hook |
| - [AIRFLOW-667] Handle BigQuery 503 error |
| - [AIRFLOW-680] Disable connection pool for commands |
| - [AIRFLOW-678] Prevent scheduler from double triggering TIs |
| - [AIRFLOW-677] Kill task if it fails to heartbeat |
| - [AIRFLOW-674] Ability to add descriptions for DAGs |
| - [AIRFLOW-682] Bump MAX_PERIODS to make mark_success work for large DAGs |
| - Use jdk selector to set required jdk |
| - [AIRFLOW-647] Restore dag.get_active_runs |
| - [AIRFLOW-662] Change seasons to months in project description |
| - [AIRFLOW-656] Add dag/task/date index to xcom table |
| - [AIRFLOW-658] Improve schema_update_options in GCP |
| - [AIRFLOW-41] Fix pool oversubscription |
| - [AIRFLOW-489] Add API Framework |
| - [AIRFLOW-653] Add some missing endpoint tests |
| - [AIRFLOW-652] Remove obsolete endpoint |
| - [AIRFLOW-345] Add contrib ECSOperator |
| - [AIRFLOW-650] Adding Celect to user list |
| - [AIRFLOW-510] Filter Paused Dags, show Last Run & Trigger Dag |
| - [AIRFLOW-643] Improve date handling for sf_hook |
| - [AIRFLOW-638] Add schema_update_options to GCP ops |
| - [AIRFLOW-640] Install and enable nose-ignore-docstring |
| - [AIRFLOW-639]AIRFLOW-639] Alphasort package names |
| - [AIRFLOW-375] Fix pylint errors |
| - [AIRFLOW-347] Show empty DAG runs in tree view |
| - [AIRFLOW-628] Adding SalesforceHook to contrib/hooks |
| - [AIRFLOW-514] hive hook loads data from pandas DataFrame into hive and infers types |
| - [AIRFLOW-565] Fixes DockerOperator on Python3.x |
| - [AIRFLOW-635] Encryption option for S3 hook |
| - [AIRFLOW-137] Fix max_active_runs on clearing tasks |
| - [AIRFLOW-343] Fix schema plumbing in HiveServer2Hook |
| - [AIRFLOW-130] Fix ssh operator macosx |
| - [AIRFLOW-633] Show TI attributes in TI view |
| - [AIRFLOW-626][AIRFLOW-1] HTML Content does not show up when sending email with attachment |
| - [AIRFLOW-533] Set autocommit via set_autocommit |
| - [AIRFLOW-629] stop pinning lxml |
| - [AIRFLOW-464] Add setdefault method to Variable |
| - [AIRFLOW-626][AIRFLOW-1] HTML Content does not show up when sending email with attachment |
| - [AIRFLOW-591] Add datadog hook & sensor |
| - [AIRFLOW-561] Add RedshiftToS3Transfer operator |
| - [AIRFLOW-570] Pass root to date form on gantt |
| - [AIRFLOW-504] Store fractional seconds in MySQL tables |
| - [AIRFLOW-623] LDAP attributes not always a list |
| - [AIRFLOW-611] source_format in BigQueryBaseCursor |
| - [AIRFLOW-619] Fix exception in Gantt chart |
| - [AIRFLOW-618] Cast DateTimes to avoid sqlite errors |
| - [AIRFLOW-422] Add JSON endpoint for task info |
| - [AIRFLOW-616][AIRFLOW-617] Minor fixes to PR tool UX |
| - [AIRFLOW-179] Fix DbApiHook with non-ASCII chars |
| - [AIRFLOW-566] Add timeout while fetching logs |
| - [AIRFLOW-615] Set graph glyphicon first |
| - [AIRFLOW-609] Add application_name to PostgresHook |
| - [AIRFLOW-604] Revert .first() to .one() |
| - [AIRFLOW-370] Create AirflowConfigException in exceptions.py |
| - [AIRFLOW-582] Fixes TI.get_dagrun filter (removes start_date) |
| - [AIRFLOW-568] Fix double task_stats count if a DagRun is active |
| - [AIRFLOW-585] Fix race condition in backfill execution loop |
| - [AIRFLOW-580] Prevent landscape warning on .format |
| - [AIRFLOW-597] Check if content is None, not false-equivalent |
| - [AIRFLOW-586] test_dag_v1 fails from 0 to 3 a.m. |
| - [AIRFLOW-453] Add XCom Admin Page |
| - [AIRFLOW-588] Add Google Cloud Storage Object sensor[] |
| - [AIRFLOW-592] example_xcom import Error |
| - [AIRFLOW-587] Fix incorrect scope for Google Auth[] |
| - [AIRFLOW-589] Add templatable job_name[] |
| - [AIRFLOW-227] Show running config in config view |
| - [AIRFLOW-319]AIRFLOW-319] xcom push response in HTTP Operator |
| - [AIRFLOW-385] Add symlink to latest scheduler log directory |
| - [AIRFLOW-583] Fix decode error in gcs_to_bq |
| - [AIRFLOW-96] s3_conn_id using environment variable |
| - [AIRFLOW-575] Clarify tutorial and FAQ about `schedule_interval` always inheriting from DAG object |
| - [AIRFLOW-577] Output BigQuery job for improved debugging |
| - [AIRFLOW-560] Get URI & SQLA engine from Connection |
| - [AIRFLOW-518] Require DataProfilingMixin for Variables CRUD |
| - [AIRFLOW-553] Fix load path for filters.js |
| - [AIRFLOW-554] Add Jinja support to Spark-sql |
| - [AIRFLOW-550] Make ssl config check empty string safe |
| - [AIRFLOW-500] Use id for github allowed teams |
| - [AIRFLOW-556] Add UI PR guidelines |
| - [AIRFLOW-358][AIRFLOW-430] Add `connections` cli |
| - [AIRFLOW-548] Load DAGs immediately & continually |
| - [AIRFLOW-539] Updated BQ hook and BQ operator to support Standard SQL. |
| - [AIRFLOW-378] Add string casting to params of spark-sql operator |
| - [AIRFLOW-544] Add Pause/Resume toggle button |
| - [AIRFLOW-333][AIRFLOW-258] Fix non-module plugin components |
| - [AIRFLOW-542] Add tooltip to DAGs links icons |
| - [AIRFLOW-530] Update docs to reflect connection environment var has to be in uppercase |
| - [AIRFLOW-525] Update template_fields in Qubole Op |
| - [AIRFLOW-480] Support binary file download from GCS |
| - [AIRFLOW-198] Implement latest_only_operator |
| - [AIRFLOW-91] Add SSL config option for the webserver |
| - [AIRFLOW-191] Fix connection leak with PostgreSQL backend |
| - [AIRFLOW-512] Fix 'bellow' typo in docs & comments |
| - [AIRFLOW-509][AIRFLOW-1] Create operator to delete tables in BigQuery |
| - [AIRFLOW-498] Remove hard-coded gcp project id |
| - [AIRFLOW-505] Support unicode characters in authors' names |
| - [AIRFLOW-494] Add per-operator success/failure metrics |
| - [AIRFLOW-488] Fix test_simple fail |
| - [AIRFLOW-468] Update panda requirement to 0.17.1 |
| - [AIRFLOW-159] Add cloud integration section + GCP documentation |
| - [AIRFLOW-477][AIRFLOW-478] Restructure security section for clarity |
| - [AIRFLOW-467] Allow defining of project_id in BigQueryHook |
| - [AIRFLOW-483] Change print to logging statement |
| - [AIRFLOW-475] make the segment granularity in Druid hook configurable |
| |
| |
| Airflow 1.7.2 |
| ------------- |
| |
| - [AIRFLOW-463] Link Airflow icon to landing page |
| - [AIRFLOW-149] Task Dependency Engine + Why Isn't My Task Running View |
| - [AIRFLOW-361] Add default failure handler for the Qubole Operator |
| - [AIRFLOW-353] Fix dag run status update failure |
| - [AIRFLOW-447] Store source URIs in Python 3 compatible list |
| - [AIRFLOW-443] Make module names unique when importing |
| - [AIRFLOW-444] Add Google authentication backend |
| - [AIRFLOW-446][AIRFLOW-445] Adds missing dataproc submit options |
| - [AIRFLOW-431] Add CLI for CRUD operations on pools |
| - [AIRFLOW-329] Update Dag Overview Page with Better Status Columns |
| - [AIRFLOW-360] Fix style warnings in models.py |
| - [AIRFLOW-425] Add white fill for null state tasks in tree view. |
| - [AIRFLOW-69] Use dag runs in backfill jobs |
| - [AIRFLOW-415] Make dag_id not found error clearer |
| - [AIRFLOW-416] Use ordinals in README's company list |
| - [AIRFLOW-369] Allow setting default DAG orientation |
| - [AIRFLOW-410] Add 2 Q/A to the FAQ in the docs |
| - [AIRFLOW-407] Add different colors for some sensors |
| - [AIRFLOW-414] Improve error message for missing FERNET_KEY |
| - [AIRFLOW-406] Sphinx/rst fixes |
| - [AIRFLOW-412] Fix lxml dependency |
| - [AIRFLOW-413] Fix unset path bug when backfilling via pickle |
| - [AIRFLOW-78] Airflow clear leaves dag_runs |
| - [AIRFLOW-402] Remove NamedHivePartitionSensor static check, add docs |
| - [AIRFLOW-394] Add an option to the Task Duration graph to show cumulative times |
| - [AIRFLOW-404] Retry download if unpacking fails for hive |
| - [AIRFLOW-276] Gunicorn rolling restart |
| - [AIRFLOW-399] Remove dags/testdruid.py |
| - [AIRFLOW-400] models.py/DAG.set_dag_runs_state() does not correctly set state |
| - [AIRFLOW-395] Fix colon/equal signs typo for resources in default config |
| - [AIRFLOW-397] Documentation: Fix typo in the word "instantiating" |
| - [AIRFLOW-395] Remove trailing commas from resources in config |
| - [AIRFLOW-388] Add a new chart for Task_Tries for each DAG |
| - [AIRFLOW-322] Fix typo in FAQ section |
| - [AIRFLOW-375] Pylint fixes |
| - limit scope to user email only AIRFLOW-386 |
| - [AIRFLOW-383] Cleanup example qubole operator dag |
| - [AIRFLOW-160] Parse DAG files through child processes |
| - [AIRFLOW-381] Manual UI Dag Run creation: require dag_id field |
| - [AIRFLOW-373] Enhance CLI variables functionality |
| - [AIRFLOW-379] Enhance Variables page functionality: import/export variables |
| - [AIRFLOW-331] modify the LDAP authentication config lines in 'Security' sample codes |
| - [AIRFLOW-356][AIRFLOW-355][AIRFLOW-354] Replace nobr, enable DAG only exists locally message, change edit DAG icon |
| - [AIRFLOW-362] Import __future__ division |
| - [AIRFLOW-359] Pin flask-login to 0.2.11 |
| - [AIRFLOW-261] Add bcc and cc fields to EmailOperator |
| - [AIRFLOW-348] Fix code style warnings |
| - [AIRFLOW-349] Add metric for number of zombies killed |
| - [AIRFLOW-340] Remove unused dependency on Babel |
| - [AIRFLOW-339]: Ability to pass a flower conf file |
| - [AIRFLOW-341][operators] Add resource requirement attributes to operators |
| - [AIRFLOW-335] Fix simple style errors/warnings |
| - [AIRFLOW-337] Add __repr__ to VariableAccessor and VariableJsonAccessor |
| - [AIRFLOW-334] Fix using undefined variable |
| - [AIRFLOW-315] Fix blank lines code style warnings |
| - [AIRFLOW-306] Add Spark-sql Hook and Operator |
| - [AIRFLOW-327] Add rename method to the FTPHook |
| - [AIRFLOW-321] Fix a wrong code example about tests/dags |
| - [AIRFLOW-316] Always check DB state for Backfill Job execution |
| - [AIRFLOW-264] Adding workload management for Hive |
| - [AIRFLOW-297] support exponential backoff option for retry delay |
| - [AIRFLOW-31][AIRFLOW-200] Add note to updating.md |
| - [AIRFLOW-307] There is no __neq__ Python magic method. |
| - [AIRFLOW-309] Add requirements of develop dependencies to docs |
| - [AIRFLOW-307] Rename __neq__ to __ne__ Python magic method. |
| - [AIRFLOW-313] Fix code style for sqoop_hook.py |
| - [AIRFLOW-311] Fix wrong path in CONTRIBUTING.md |
| - [AIRFLOW-24] DataFlow Java Operator |
| - [AIRFLOW-308] Add link to refresh DAG within DAG view header |
| - [AIRFLOW-314] Fix BigQuery cursor run_table_upsert method |
| - [AIRFLOW-298] fix incubator disclaimer in docs |
| - [AIRFLOW-284] HiveServer2Hook fix for cursor scope for get_results |
| - [AIRFLOW-260] More graceful exit when issues can't be closed |
| - [AIRFLOW-260] Handle case when no version is found |
| - [AIRFLOW-228] Handle empty version list in PR tool |
| - [AIRFLOW-302] Improve default squash commit message |
| - [AIRFLOW-187] Improve prompt styling |
| - [AIRFLOW-187] Fix typo in argument name |
| - [AIRFLOW-187] Move "Close XXX" message to end of squash commit |
| - [AIRFLOW-247] Add EMR hook, operators and sensors. Add AWS base hook |
| - [AIRFLOW-301] Fix broken unit test |
| - [AIRFLOW-100] Add execution_date_fn to ExternalTaskSensor |
| - [AIRFLOW-282] Remove PR Tool logic that depends on version formatting |
| - [AIRFLOW-291] Add index for state in TI table |
| - [AIRFLOW-269] Add some unit tests for PostgreSQL |
| - [AIRFLOW-296] template_ext is being treated as a string rather than a tuple in qubole operator |
| - [AIRFLOW-286] Improve FTPHook to implement context manager interface |
| - [AIRFLOW-243] Create NamedHivePartitionSensor |
| - [AIRFLOW-246] Improve dag_stats endpoint query |
| - [AIRFLOW-189] Highlighting of Parent/Child nodes in Graphs |
| - [ARFLOW-255] Check dagrun timeout when comparing active runs |
| - [AIRFLOW-281] Add port to mssql_hook |
| - [AIRFLOW-285] Use Airflow 2.0 style imports for all remaining hooks/operators |
| - [AIRFLOW-40] Add LDAP group filtering feature. |
| - [AIRFLOW-277] Multiple deletions does not work in Task Instances view if using SQLite backend |
| - [AIRFLOW-200] Make hook/operator imports lazy, and print proper exceptions |
| - [AIRFLOW-283] Make store_to_xcom_key a templated field in GoogleCloudStorageDownloadOperator |
| - [AIRFLOW-278] Support utf-8 encoding for SQL |
| - [AIRFLOW-280] clean up tmp druid table no matter if an ingestion job succeeds or not |
| - [AIRFLOW-274] Add XCom functionality to GoogleCloudStorageDownloadOperator |
| - [AIRFLOW-273] Create an svg version of the Airflow logo. |
| - [AIRFLOW-275] Update contributing guidelines |
| - [AIRFLOW-244] Modify hive operator to inject analysis data |
| - [AIRFLOW-162] Allow variable to be accessible into templates |
| - [AIRFLOW-248] Add Apache license header to all files |
| - [AIRFLOW-263] Remove temp backtick file |
| - [AIRFLOW-252] Raise Sqlite exceptions when deleting tasks instance in WebUI |
| - [AIRFLOW-180] Fix timeout behavior for sensors |
| - [AIRFLOW-262] Simplify commands in MANIFEST.in |
| - [AIRFLOW-31] Add zope dependency |
| - [AIRFLOW-6] Remove dependency on Highcharts |
| - [AIRFLOW-234] make task that are not `running` self-terminate |
| - [AIRFLOW-256] Fix test_scheduler_reschedule heartrate |
| - Add Python 3 compatibility fix |
| - [AIRFLOW-31] Use standard imports for hooks/operators |
| - [AIRFLOW-173] Initial implementation of FileSensor |
| - [AIRFLOW-224] Collect orphaned tasks and reschedule them |
| - [AIRFLOW-239] Fix tests indentation |
| - [AIRFLOW-225] Better units for task duration graph |
| - [AIRFLOW-241] Add testing done section to PR template |
| - [AIRFLOW-222] Show duration of task instances in ui |
| - [AIRFLOW-231] Do not eval user input in PrestoHook |
| - [AIRFLOW-216] Add Sqoop Hook and Operator |
| - [AIRFLOW-171] Add upgrade notes on email and S3 to 1.7.1.2 |
| - [AIRFLOW-238] Make compatible with flask-admin 1.4.1 |
| - [AIRFLOW-230][HiveServer2Hook] adding multi statements support |
| - [AIRFLOW-142] setup_env.sh doesn't download hive tarball if hdp is specified as distro |
| - [AIRFLOW-223] Make parametable the IP on which Flower binds to |
| - [AIRFLOW-218] Added option to enable webserver gunicorn access/err logs |
| - [AIRFLOW-213] Add "Closes #X" phrase to commit messages |
| - [AIRFLOW-68] Align start_date with the schedule_interval |
| - [AIRFLOW-9] Improving docs to meet Apache's standards |
| - [AIRFLOW-131] Make XCom.clear more selective |
| - [AIRFLOW-214] Fix occasion of detached taskinstance |
| - [AIRFLOW-206] Add commit to close PR |
| - [AIRFLOW-206] Always load local log files if they exist |
| - [AIRFLOW-211] Fix JIRA "resolve" vs "close" behavior |
| - [AIRFLOW-64] Add note about relative DAGS_FOLDER |
| - [AIRFLOW-114] Sort plugins dropdown |
| - [AIRFLOW-209] Add scheduler tests and improve lineage handling |
| - [AIRFLOW-207] Improve JIRA auth workflow |
| - [AIRFLOW-187] Improve PR tool UX |
| - [AIRFLOW-155] Documentation of Qubole Operator |
| - Optimize and refactor process_dag |
| - [AIRFLOW-185] Handle empty versions list |
| - [AIRFLOW-201] Fix for HiveMetastoreHook + kerberos |
| - [AIRFLOW-202]: Fixes stray print line |
| - [AIRFLOW-196] Fix bug that exception is not handled in HttpSensor |
| - [AIRFLOW-195] : Add toggle support to subdag clearing in the CLI |
| - [AIRFLOW-23] Support for Google Cloud DataProc |
| - [AIRFLOW-25] Configuration for Celery always required |
| - [AIRFLOW-190] Add codecov and remove download count |
| - [AIRFLOW-168] Correct evaluation of @once schedule |
| - [AIRFLOW-183] Fetch log from remote when worker returns 4xx/5xx response |
| - [AIRFLOW-181] Fix failing unpacking of hadoop by redownloading |
| - [AIRFLOW-176] remove unused formatting key |
| - [AIRFLOW-167]: Add dag_state option in cli |
| - [AIRFLOW-178] Fix bug so that zip file is detected in DAG folder |
| - [AIRFLOW-176] Improve PR Tool JIRA workflow |
| - AIRFLOW-45: Support Hidden Airflow Variables |
| - [AIRFLOW-175] Run git-reset before checkout in PR tool |
| - [AIRFLOW-157] Make PR tool Py3-compat; add JIRA command |
| - [AIRFLOW-170] Add missing @apply_defaults |
| |
| Airflow 1.7.1, 2016-05-19 |
| ------------------------- |
| |
| - Fix : Don't treat premature tasks as could_not_run tasks |
| - AIRFLOW-92 Avoid unneeded upstream_failed session closes apache/airflow#1485 |
| - Add logic to lock DB and avoid race condition |
| - Handle queued tasks from multiple jobs/executors |
| - AIRFLOW-52 Warn about overwriting tasks in a DAG |
| - Fix corner case with joining processes/queues (#1473) |
| - [AIRFLOW-52] Fix bottlenecks when working with many tasks |
| - Add columns to toggle extra detail in the connection list view. |
| - Log the number of errors when importing DAGs |
| - Log dagbag metrics duplicate messages in queue into Statsd (#1406) |
| - Clean up issue template (#1419) |
| - correct missed arg.foreground to arg.daemon in cli |
| - Reinstate imports for github enterprise auth |
| - Use os.execvp instead of subprocess.Popen for the webserver |
| - Revert from using "--foreground" to "--daemon" |
| - Implement a Cloudant hook |
| - Add missing args to `airflow clear` |
| - Fixed a bug in the scheduler: num_runs used where runs intended |
| - Add multiprocessing support to the scheduler |
| - Partial fix to make sure next_run_date cannot be None |
| - Support list/get/set variables in the CLI |
| - Properly handle BigQuery booleans in BigQuery hook. |
| - Added the ability to view XCom variables in webserver |
| - Change DAG.tasks from a list to a dict |
| - Add support for zipped dags |
| - Stop creating hook on instantiating of S3 operator |
| - User subquery in views to find running DAGs |
| - Prevent DAGs from being reloaded on every scheduler iteration |
| - Add a missing word to docs |
| - Document the parameters of `DbApiHook` |
| - added oracle operator with existing oracle hook |
| - Add PyOpenSSL to Google Cloud gcp_api. |
| - Remove executor error unit test |
| - Add DAG inference, deferral, and context manager |
| - Don't return error when writing files to Google cloud storage. |
| - Fix GCS logging for gcp_api. |
| - Ensure attr is in scope for error message |
| - Fixing misnamed PULL_REQUEST_TEMPLATE |
| - Extract non_pooled_task_slot_count into a configuration param |
| - Update plugins.rst for clarity on the example (#1309) |
| - Fix s3 logging issue |
| - Add twitter feed example dag |
| - GitHub ISSUE_TEMPLATE & PR_TEMPLATE cleanup |
| - Reduce logger verbosity |
| - Adding a PR Template |
| - Add Lucid to list of users |
| - Fix usage of asciiart |
| - Use session instead of outdated main_session for are_dependencies_met |
| - Fix celery flower port allocation |
| - Fix for missing edit actions due to flask-admin upgrade |
| - Fix typo in comment in prioritize_queued method |
| - Add HipchatOperator |
| - Include all example dags in backfill unit test |
| - Make sure skipped jobs are actually skipped |
| - Fixing a broken example dag, example_skip_dag.py |
| - Add consistent and thorough signal handling and logging |
| - Allow Operators to specify SKIPPED status internally |
| - Update docstring for executor trap unit test |
| - Doc: explain the usage of Jinja templating for templated params |
| - Don't schedule runs before the DAG's start_date |
| - Fix infinite retries with pools, with test |
| - Fix handling of deadlocked jobs |
| - Show only Airflow's deprecation warnings |
| - Set DAG_FOLDER for unit tests |
| - Missing comma in setup.py |
| - Deprecate args and kwargs in BaseOperator |
| - Raise deep scheduler exceptions to force a process restart. |
| - Change inconsistent example DAG owners |
| - Fix module path of send_email_smtp in configuration |
| - added Gentner Lab to list of users |
| - Increase timeout time for unit test |
| - Fix reading strings from conf |
| - CHORE - Remove Trailing Spaces |
| - Fix SSHExecuteOperator crash when using a custom ssh port |
| - Add note about Airflow components to template |
| - Rewrite BackfillJob logic for clarity |
| - Add unit tests |
| - Fix miscellaneous bugs and clean up code |
| - Fix logic for determining DagRun states |
| - Make SchedulerJob not run EVERY queued task |
| - Improve BackfillJob handling of queued/deadlocked tasks |
| - Introduce ignore_depends_on_past parameters |
| - Use Popen with CeleryExecutor |
| - Rename user table to users to avoid conflict with postgres |
| - Beware of negative pool slots. |
| - Add support for calling_format from boto to S3_Hook |
| - Add PyPI meta data and sync version number |
| - Set dags_are_paused_at_creation's default value to True |
| - Resurface S3Log class eaten by rebase/push -f |
| - Add missing session.commit() at end of initdb |
| - Validate that subdag tasks have pool slots available, and test |
| - Use urlparse for remote GCS logs, and add unit tests |
| - Make webserver worker timeout configurable |
| - Fixed scheduling for @once interval |
| - Use psycopg2's API for serializing postgres cell values |
| - Make the provide_session decorator more robust |
| - update link to Lyft's website |
| - use num_shards instead of partitions to be consistent with batch ingestion |
| - Add documentation links to README |
| - Update docs with separate configuration section |
| - Fix airflow.utils deprecation warning code being Python 3 incompatible |
| - Extract dbapi cell serialization into its own method |
| - Set Postgres autocommit as supported only if server version is < 7.4 |
| - Use refactored utils module in unit test imports |
| - Add changelog for 1.7.0 |
| - Use LocalExecutor on Travis if possible |
| - remove unused logging,errno, MiniHiveCluster imports |
| - remove extra import of logging lib |
| - Fix required gcloud version |
| - Refactoring utils into smaller submodules |
| - Properly measure number of task retry attempts |
| - Add function to get configuration as dict, plus unit tests |
| - Merge branch 'master' into hivemeta_sasl |
| - Add wiki link to README.md |
| - [hotfix] make email.Utils > email.utils for py3 |
| - Add the missing "Date" header to the warning e-mails |
| - Add the missing "Date" header to the warning e-mails |
| - Check name of SubDag class instead of class itself |
| - [hotfix] removing repo_token from .coveralls.yml |
| - Set the service_name in coverals.yml |
| - Fixes #1223 |
| - Update Airflow docs for remote logging |
| - Add unit tests for trapping Executor errors |
| - Make sure Executors properly trap errors |
| - Fix HttpOpSensorTest to use fake request session |
| - Linting |
| - Add an example on pool usage in the documentation |
| - Add two methods to bigquery hook's base cursor: run_table_upsert, which adds a table or updates an existing table; and run_grant_dataset_view_access, which grants view access to a given dataset for a given table. |
| - Tasks references upstream and downstream tasks using strings instead of references |
| - Fix typos in models.py |
| - Fix broken links in documentation |
| - [hotfix] fixing the Scheduler CLI to make dag_id optional |
| - Update link to Common Pitfalls wiki page in README |
| - Allow disabling periodic committing when inserting rows with DbApiHook |
| - added Glassdoor to "who uses airflow" |
| - Fix typo preventing from launching webserver |
| - Documentation badge |
| - Fixing ISSUE_TEMPLATE name to include .md suffix |
| - Adding an ISSUE_TEMPLATE to ensure that issues are adequately defined |
| - Linting & debugging |
| - Refactoring the CLI to be data-driven |
| - Updating the Bug Reporting protocol in the Contributing.md file |
| - Fixing the docs |
| - Clean up references to old session |
| - remove session reference |
| - resolve conflict |
| - clear xcom data when task instance starts |
| - replace main_session with @provide_session |
| - Add extras to installation.rst |
| - Changes to Contributing to reflect more closely the current state of development. |
| - Modifying README to link to the wiki committer list |
| - docs: fixes a spelling mistake in default config |
| - Set killMode to 'control-group' for webservice.service |
| - Set KillMode to 'control-group' for worker.service |
| - Linting |
| - Fix WebHdfsSensor |
| - Adding more licenses to pass checks |
| - fixing landscape's config |
| - [hotfix] typo that made it in master |
| - [hotfix] fixing landscape requirement detection |
| - Make testing on hive conditional |
| - Merge remote-tracking branch 'upstream/master' into minicluster |
| - Update README.md |
| - Throwing in a few license to pass the build |
| - Adding a reqs.txt for landscape.io |
| - Pointing to a reqs file |
| - Some linting |
| - Adding a .landscape.yml file |
| - badge for PyPI version |
| - Add license and ignore for sql and csv |
| - Use correct connection id |
| - Use correct table name |
| - Provide data for ci tests |
| - New badge for showing staleness of reqs |
| - Removing requirements.txt as it is uni-dimensional |
| - Make it work on py3 |
| - Remove decode for logging |
| - Also keep py2 compatible |
| - More py3 fixes |
| - Convert to bytes for py3 compat |
| - Make sure to be py3 compatible |
| - Use unicodecsv to make it py3 compatible |
| - Replace tab with spaces Remove unused import |
| - Merge remote-tracking branch 'upstream/master' |
| - Support decimal types in MySQL to GCS |
| - Make sure to write binary as string can be unicode |
| - Ignore metastore |
| - More impyla fixes |
| - Test HivemetaStore if Python 2 |
| - Allow users to set hdfs_namenode_principal in HDFSHook config |
| - Add tests for Hiveserver2 and fix some issues from impyla |
| - Merge branch 'impyla' into minicluster |
| - This patch allows for testing of hive operators and hooks. Sasl is used (NoSasl in connection string is not possible). Tests have been adjusted. |
| - Treat SKIPPED and SUCCESS the same way when evaluating depends_on_past=True |
| - fix bigquery hook |
| - Version cap for gcp_api |
| - Fix typo when returning VerticaHook |
| - Adding fernet key to use it as part of stdout commands |
| - Adding support for ssl parameters. (picking up from jthomas123) |
| - More detail in error message. |
| - Make sure paths don't conflict bc of trailing / |
| - Change gcs_hook to self.hook |
| - Refactor remote log read/write and add GCS support |
| - Only use multipart upload in S3Hook if file is large enough |
| - Merge branch 'airbnb/master' |
| - Add GSSAPI SASL to HiveMetaStoreHook. |
| - Add warning for deprecated setting |
| - Use kerberos_service_name = 'hive' as standard instead of 'impala'. |
| - Use GSSAPI instead of KERBEROS and provide backwards compatibility |
| - ISSUE-1123 Use impyla instead of pyhs2 |
| - Set celery_executor to use queue name as exchange |