Translate 2016-07-00-Bringing-End-To-End-Kubernetes-Testing-To-Azure-2.md (#25536)
* Create 2016-07-00-Bringing-End-To-End-Kubernetes-Testing-To-Azure-2.md zh-trans 2016-07-00-Bringing-End-To-End-Kubernetes-Testing-To-Azure-2.md * Update content/zh/blog/_posts/2016-07-00-Bringing-End-To-End-Kubernetes-Testing-To-Azure-2.md * Update content/zh/blog/_posts/2016-07-00-Bringing-End-To-End-Kubernetes-Testing-To-Azure-2.mdpull/25846/head
parent
96a770c811
commit
173222fa60
|
@ -0,0 +1,116 @@
|
|||
---
|
||||
题目: " 将端到端的 Kubernetes 测试引入 Azure (第二部分) "
|
||||
日期: 2016-07-18
|
||||
slug: bringing-end-to-end-kubernetes-testing-to-azure-2
|
||||
url: /blog/2016/07/Bringing-End-To-End-Kubernetes-Testing-To-Azure-2
|
||||
---
|
||||
<!--
|
||||
---
|
||||
title: " Bringing End-to-End Kubernetes Testing to Azure (Part 2) "
|
||||
date: 2016-07-18
|
||||
slug: bringing-end-to-end-kubernetes-testing-to-azure-2
|
||||
url: /blog/2016/07/Bringing-End-To-End-Kubernetes-Testing-To-Azure-2
|
||||
---
|
||||
-->
|
||||
|
||||
<!--
|
||||
_Editor’s Note: Today’s guest post is Part II from a [series](https://kubernetes.io/blog/2016/06/bringing-end-to-end-testing-to-azure) by Travis Newhouse, Chief Architect at AppFormix, writing about their contributions to Kubernetes._
|
||||
-->
|
||||
_作者标注:今天的邀请帖子是 Travis Newhouse 的 [系列](https://kubernetes.io/blog/2016/06/bringing-end-to-end-testing-to-azure) 中的第二部分,他是 AppFormix 的首席架构师,这篇文章介绍了他们对 Kubernetes 的贡献。_
|
||||
|
||||
|
||||
<!--
|
||||
Historically, Kubernetes testing has been hosted by Google, running e2e tests on [Google Compute Engine](https://cloud.google.com/compute/) (GCE) and [Google Container Engine](https://cloud.google.com/container-engine/) (GKE). In fact, the gating checks for the submit-queue are a subset of tests executed on these test platforms. Federated testing aims to expand test coverage by enabling organizations to host test jobs for a variety of platforms and contribute test results to benefit the Kubernetes project. Members of the Kubernetes test team at Google and SIG-Testing have created a [Kubernetes test history dashboard](http://storage.googleapis.com/kubernetes-test-history/static/index.html) that publishes the results from all federated test jobs (including those hosted by Google).
|
||||
|
||||
In this blog post, we describe extending the e2e test jobs for Azure, and show how to contribute a federated test to the Kubernetes project.
|
||||
-->
|
||||
历史上,Kubernetes 测试一直由谷歌托管,在 [谷歌计算引擎](https://cloud.google.com/compute/) (GCE) 和 [谷歌容器引擎](https://cloud.google.com/container-engine/) (GKE) 上运行端到端测试。实际上,提交队列的选通检查是在这些测试平台上执行测试的子集。联合测试旨在通过使组织托管各种平台的测试作业并贡献测试结果,从而让 Kubernetes 项目受益来扩大测试范围。谷歌和 SIG-Testing 的 Kubernetes 测试小组成员已经创建了一个 [Kubernetes 测试历史记录仪表板](http://storage.googleapis.com/kubernetes-test-history/static/index.html),可以发布所有联合测试作业(包括谷歌托管的作业)的全部结果。
|
||||
|
||||
在此博客文章中,我们介绍了扩展 Azure 的端到端测试工作,并展示了如何为 Kubernetes 项目贡献联合测试。
|
||||
|
||||
<!--
|
||||
**END-TO-END INTEGRATION TESTS FOR AZURE**
|
||||
|
||||
After successfully implementing [“development distro” scripts to automate deployment of Kubernetes on Azure](https://kubernetes.io/blog/2016/06/bringing-end-to-end-testing-to-azure), our next goal was to run e2e integration tests and share the results with the Kubernetes community.
|
||||
-->
|
||||
**Azure 的端到端集成测试**
|
||||
|
||||
成功实现 [在 Azure 上自动部署 Kubernetes 的 “development distro” 脚本](https://kubernetes.io/blog/2016/06/bringing-end-to-end-testing-to-azure) 之后,我们的下一个目标是运行端到端集成测试,并与 Kubernetes 社区共享结果。
|
||||
|
||||
<!--
|
||||
We automated our workflow for executing e2e tests of Kubernetes on Azure by defining a nightly job in our private Jenkins server. Figure 2 shows the workflow that uses kube-up.sh to deploy Kubernetes on Ubuntu virtual machines running in Azure, then executes the e2e tests. On completion of the tests, the job uploads the test results and logs to a Google Cloud Storage directory, in a format that can be processed by the [scripts that produce the test history dashboard](https://github.com/kubernetes/test-infra/tree/master/jenkins/test-history). Our Jenkins job uses the hack/jenkins/e2e-runner.sh and hack/jenkins/upload-to-gcs.sh scripts to produce the results in the correct format.
|
||||
-->
|
||||
通过在私有 Jenkins 服务器中定义夜间工作,我们自动化了在 Azure 上执行 Kubernetes 端到端测试的工作流程。图2显示了使用 kube-up.sh 在运行于 Azure 的 Ubuntu 虚拟机上部署 Kubernetes,然后执行端到端测试的工作流程。测试完成后,该作业将测试结果和日志上传到 Google Cloud Storage 目录中,其格式可以由 [生成测试历史记录仪表板的脚本](https://github.com/kubernetes/test-infra/tree/master/jenkins/test-history) 进行处理。我们的 Jenkins 作业使用 hack/jenkins/e2e-runner.sh 和 hack/jenkins/upload-to-gcs.sh 脚本生成正确格式的结果。
|
||||
|
||||
<!--
|
||||
|  |
|
||||
| Figure 2 - Nightly test job workflow |
|
||||
-->
|
||||
|  |
|
||||
| 图 2 - 夜间测试工作流程 |
|
||||
|
||||
<!--
|
||||
**HOW TO CONTRIBUTE AN E2E TEST**
|
||||
|
||||
Throughout our work to create the Azure e2e test job, we have collaborated with members of [SIG-Testing](https://github.com/kubernetes/community/tree/master/sig-testing) to find a way to publish the results to the Kubernetes community. The results of this collaboration are documentation and a streamlined process to contribute results from a federated test job. The steps to contribute e2e test results can be summarized in 4 steps.
|
||||
-->
|
||||
**如何进行端到端测试**
|
||||
|
||||
在创建 Azure 端到端测试工作的整个过程中,我们与 [SIG-Testing](https://github.com/kubernetes/community/tree/master/sig-testing) 的成员进行了合作,找到了一种将结果发布到 Kubernetes 社区的方法。合作的结果是以文档和简化的流程从联合测试工作中贡献结果。贡献端到端测试结果的过程可以归纳为4个步骤。
|
||||
|
||||
<!--
|
||||
1. Create a [Google Cloud Storage](https://cloud.google.com/storage/) bucket in which to publish the results.
|
||||
2. Define an automated job to run the e2e tests. By setting a few environment variables, hack/jenkins/e2e-runner.sh deploys Kubernetes binaries and executes the tests.
|
||||
3. Upload the results using hack/jenkins/upload-to-gcs.sh.
|
||||
4. Incorporate the results into the test history dashboard by submitting a pull-request with modifications to a few files in [kubernetes/test-infra](https://github.com/kubernetes/test-infra).
|
||||
-->
|
||||
1. 创建一个 [Google Cloud Storage](https://cloud.google.com/storage/) 空间用来发布结果。
|
||||
2. 定义一个自动化作业来运行端到端测试,通过设置一些环境变量,使用 hack/jenkins/e2e-runner.sh 部署 Kubernetes 二进制文件并执行测试。
|
||||
3. 使用 hack/jenkins/upload-to-gcs.sh 上传结果。
|
||||
4. 通过提交对 [kubernetes/test-infra](https://github.com/kubernetes/test-infra) 中的几个文件进行修改的请求,将结果合并到测试历史记录仪表板中。
|
||||
|
||||
<!--
|
||||
The federated tests documentation describes these steps in more detail. The scripts to run e2e tests and upload results simplifies the work to contribute a new federated test job. The specific steps to set up an automated test job and an appropriate environment in which to deploy Kubernetes are left to the reader’s preferences. For organizations using Jenkins, the jenkins-job-builder configurations for GCE and GKE tests may provide helpful examples.
|
||||
-->
|
||||
联合测试文档更详细地描述了这些步骤。运行端到端测试并上传结果的脚本简化了贡献新联合测试作业的工作量。设置自动化测试作业的具体步骤以及在其中部署 Kubernetes 的合适环境将留给读者进行选择。对于使用 Jenkins 的组织,用于 GCE 和 GKE 测试的 jenkins-job-builder 配置可能会提供有用的示例。
|
||||
|
||||
|
||||
<!--
|
||||
**RETROSPECTIVE**
|
||||
|
||||
The e2e tests on Azure have been running for several weeks now. During this period, we have found two issues in Kubernetes. Weixu Zhuang immediately published fixes that have been merged into the Kubernetes master branch.
|
||||
-->
|
||||
**回顾**
|
||||
|
||||
Azure 上的端到端测试已经运行了几周。在此期间,我们在 Kubernetes 中发现了两个问题。Weixu Zhuang 立即发布了修补程序并已合并到 Kubernetes master 分支中。
|
||||
|
||||
<!--
|
||||
The first issue happened when we wanted to bring up the Kubernetes cluster using SaltStack on Azure using Ubuntu VMs. A commit (07d7cfd3) modified the OpenVPN certificate generation script to use a variable that was only initialized by scripts in the cluster/ubuntu. Strict checking on existence of parameters by the certificate generation script caused other platforms that use the script to fail (e.g. our changes to support Azure). We submitted a [pull-request that fixed the issue](https://github.com/kubernetes/kubernetes/pull/21357) by initializing the variable with a default value to make the certificate generation scripts more robust across all platform types.
|
||||
-->
|
||||
当我们想用 Ubuntu VM 在 Azure 上用 SaltStack 打开 Kubernetes 集群时,发生了第一个问题。一个提交 (07d7cfd3) 修改了 OpenVPN 证书生成脚本,使用了一个仅由集群或者ubuntu中的脚本初始化的变量。证书生成脚本对参数是否存在进行严格检查会导致其他使用该脚本的平台失败(例如,为支持 Azure 而进行的更改)。我们提交了一个[解决问题的请求](https://github.com/kubernetes/kubernetes/pull/21357) ,通过使用默认值初始化变量让证书生成脚本在所有平台类型上都更加健壮,。
|
||||
|
||||
<!--
|
||||
The second [pull-request cleaned up an unused import](https://github.com/kubernetes/kubernetes/pull/22321) in the Daemonset unit test file. The import statement broke the unit tests with golang 1.4. Our nightly Jenkins job helped us find this error and we promptly pushed a fix for it.
|
||||
-->
|
||||
第二个 [清理未使用导入的请求](https://github.com/kubernetes/kubernetes/pull/22321) 在 Daemonset 单元测试文件中。import 语句打破了 golang 1.4 的单元测试。我们的夜间 Jenkins 工作帮助我们找到错误并且迅速完成修复。
|
||||
|
||||
<!--
|
||||
**CONCLUSION AND FUTURE WORK**
|
||||
-->
|
||||
**结论与未来工作**
|
||||
|
||||
<!--
|
||||
The addition of a nightly e2e test job for Kubernetes on Azure has helped to define the process to contribute a federated test to the Kubernetes project. During the course of the work, we also saw the immediate benefit of expanding test coverage to more platforms when our Azure test job identified compatibility issues.
|
||||
-->
|
||||
在 Azure 上为 Kubernetes 添加了夜间端到端测试工作,这有助于定义为 Kubernetes 项目贡献联合测试的过程。在工作过程中,当 Azure 测试工作发现兼容性问题时,我们还发现了将测试覆盖范围扩展到更多平台的直接好处。
|
||||
|
||||
<!--
|
||||
We want to thank Aaron Crickenberger, Erick Fejta, Joe Finney, and Ryan Hutchinson for their help to incorporate the results of our Azure e2e tests into the Kubernetes test history. If you’d like to get involved with testing to create a stable, high quality releases of Kubernetes, join us in the [Kubernetes Testing SIG (sig-testing)](https://github.com/kubernetes/community/tree/master/sig-testing).
|
||||
-->
|
||||
我们要感谢 Aaron Crickenberger, Erick Fejta, Joe Finney 和 Ryan Hutchinson 的帮助,将我们的 Azure 端到端测试结果纳入了 Kubernetes 测试历史。如果您想参与测试来创建稳定的、高质量的 Kubernetes 版本,请加入我们的 [Kubernetes Testing SIG (sig-testing)](https://github.com/kubernetes/community/tree/master/sig-testing)。
|
||||
|
||||
|
||||
<!--
|
||||
_--Travis Newhouse, Chief Architect at AppFormix_
|
||||
-->
|
||||
_--Travis Newhouse, AppFormix 首席架构师_
|
Loading…
Reference in New Issue