Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[AIRFLOW-3937] KubernetesPodOperator support for envFrom configMapRef… #4772

Merged

Conversation

galuszkak
Copy link
Contributor

@galuszkak galuszkak commented Feb 25, 2019

… and secretRef

Make sure you have checked all steps below.

Jira

Description

  • Here are some details about my PR:
  • My PR add support for envFrom in k8s from ConfigMap and Secret

Tests

  • My PR adds the following unit tests:
  • test_envs_from_secrets
  • test_envs_from_configmaps

Documentation

  • In case of new functionality, my PR adds documentation that describes how to use it.
    • When adding new operators/hooks/sensors, the autoclass documentation generation needs to be added.
    • All the public functions and the classes in the PR contain docstrings that explain what it does

Code Quality

  • Passes flake8

@galuszkak galuszkak force-pushed the feature/airflow-3937-k8s-envfrom-support branch 4 times, most recently from 86ec479 to 1ecbe7d Compare February 25, 2019 13:54
@feng-tao
Copy link
Member

PTAL @dimberman

@galuszkak
Copy link
Contributor Author

@feng-tao what date this should be ready so it can land in 1.10.3 ? I'm asking so I could know what priority this PR should be for me.

@feng-tao
Copy link
Member

feng-tao commented Mar 1, 2019

@ashb may know better for the date.

@galuszkak galuszkak force-pushed the feature/airflow-3937-k8s-envfrom-support branch 12 times, most recently from fc971bb to c1b6c72 Compare March 5, 2019 16:30
@galuszkak
Copy link
Contributor Author

@feng-tao @ashb @pgagnon this PR is ready for review, I've incorporated most of the requested changes here. Tests are finally passing, I've added documentation.

PS. I don't know how to setup unit testing locally with K8S, on my macOS, so it took me a while debugging with TravisCI. It was kinda annoying but not sure how can I fix that for future so I can run all tests locally on macOS...

@galuszkak galuszkak force-pushed the feature/airflow-3937-k8s-envfrom-support branch 3 times, most recently from 5845c4b to 2674ede Compare March 11, 2019 11:46
@galuszkak galuszkak force-pushed the feature/airflow-3937-k8s-envfrom-support branch from 3448241 to d6de6ce Compare March 19, 2019 21:39
@galuszkak
Copy link
Contributor Author

@ashb I've applied Your feedback, and made unittest mocked rather than calling k8s and checking values back

@ashb
Copy link
Member

ashb commented Mar 19, 2019

@galuszkak sorry - that example wasn't so great - we now aren't actually testing the behaviour of the pod factory functions.

Somewhere in the tests I'd like to see something like

self.assertEqual(
     SOMETHING['spec']['containers'][0]['envFrom'],
     { 'secretRef': { 'name': 'secret-name' } },
)

or similar.

Maybe we can do this like this:

    @mock.patch("airflow.contrib.kubernetes.pod_launcher.PodLauncher._monitor_pod")
    @mock.patch("airflow.contrib.kubernetes.kube_client.get_kube_client")
    def test_envs_from_secrets(self, client_mock, _):
        # GIVEN
        from airflow.utils.state import State
        secrets = [Secret('env', None, "secret_name")]
        mock_resp = MagicMock()
        mock_resp.status.start_time = datetime.now()
        client_mock.create_namespaced_pod.return_value = mock_resp

        # WHEN
        k = KubernetesPodOperator(
            namespace='default',
            image="ubuntu:16.04",
            cmds=["bash", "-cx"],
            arguments=["echo 10"],
            secrets=secrets,
            labels={"foo": "bar"},
            name="test",
            task_id="task",
        )
        k.execute(None)
        # THEN

        req = client_mock.create_namespaced_pod.call_args[0][1]['req']

       self.assertEqual(
           req['spec']['containers'][0]['envFrom'],
            { 'secretRef': { 'name': 'secret-name' } },
       )

Note: this is untested, and we may need to mock some extra methods

@galuszkak galuszkak force-pushed the feature/airflow-3937-k8s-envfrom-support branch from d6de6ce to ab17857 Compare March 19, 2019 22:10
@galuszkak
Copy link
Contributor Author

@ashb can I understand reasoning behind that, why we want to test that now? None of the tests were testing output of KubernetesRequestFactory before, only classes like Pod/PodLauncher to check if fields there are correct.

If we want to start testing that, I believe there should be separate ticket to make sure we cover most of the cases of outputs of KubernetesRequestFactory that is actually producing what we want in every case. Because for now there isn't single assertion on product of that class, only abstraction on top of it.

@ashb
Copy link
Member

ashb commented Mar 25, 2019

@dimberman Final thoughts? I'm okay leaving my requested test change to #4952.

@galuszkak galuszkak force-pushed the feature/airflow-3937-k8s-envfrom-support branch 3 times, most recently from 2927aac to 3c26b94 Compare March 26, 2019 09:05
@galuszkak
Copy link
Contributor Author

@ashb @dimberman hope now it's good to go! I've applied requested changes.

@galuszkak galuszkak force-pushed the feature/airflow-3937-k8s-envfrom-support branch from 709a8d0 to 32bb442 Compare March 26, 2019 17:33
@galuszkak
Copy link
Contributor Author

@ashb I've rebase Your changes.

@ashb
Copy link
Member

ashb commented Mar 26, 2019

Thanks - if I was paying more attention I could have merged it (and squashed it) on Github. The reason Why I changed it from __ to _ is that __ is generally reserved for Python internals.

@galuszkak
Copy link
Contributor Author

For me __ always meant private (because it cannot be overwritten), and _ protected (because it can be overwritten). Mostly because of this:
https://docs.python.org/3.7/tutorial/classes.html#private-variables

But I get Your point, I think this is just part of preference, how to think about API design.

@ashb
Copy link
Member

ashb commented Mar 26, 2019

Oh I didn't know that __foo actually did something specific. Still: I don't think anything should be private. If an advanced user want's to subclass and change behaviour, let the,

@galuszkak
Copy link
Contributor Author

galuszkak commented Mar 26, 2019

@ashb I agree, I just take literally what @dimberman wanted as he would like this as private helper, which I took very literally ;).

Thanks for hard work, and a lot of those code review. It was a really good experience for me, although a little longer than expected ;). Again thank You!

@ashb ashb dismissed dimberman’s stale review March 27, 2019 10:08

Changes made.

@ashb ashb merged commit 85f0e08 into apache:master Mar 27, 2019
ashb pushed a commit that referenced this pull request Mar 27, 2019
@galuszkak
Copy link
Contributor Author

Thanks for merging it! Big thanks for support and help for @FlyrInc !

@galuszkak galuszkak deleted the feature/airflow-3937-k8s-envfrom-support branch March 27, 2019 14:30
davlum pushed a commit to davlum/incubator-airflow that referenced this pull request Mar 28, 2019
cthenderson pushed a commit to cthenderson/apache-airflow that referenced this pull request Apr 16, 2019
andriisoldatenko pushed a commit to andriisoldatenko/airflow that referenced this pull request Jul 26, 2019
wmorris75 pushed a commit to modmed/incubator-airflow that referenced this pull request Jul 29, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants