출시 직전 수천 개의 결함 주문 / 처리

Aug 16 2020

이 질문은 정말 좋은 회사와의 인터뷰에서 저에게 요청되었습니다. 아래에 우리의 상호 작용 형태로 질문을 제공 할 것입니다 (M : me & I : interviewer). 명확한 답변은 없지만 무엇 을 알아야 합니다. 면접관이 정말로 원했던 아이디어 / 답변 :

I : 시나리오는 당신과 다른 2 명이 테스트 팀으로 구성되어 있습니다. 리더는 자동화를 수행 할 수있는 유일한 사람이고 다른 사람은 수동 테스트 만 수행 할 수 있습니다. 거의 10,000 개의 버그가 발생했으며이 제품이 배송되기까지 4 ~ 5 주가 남았습니다. 제품이 제 시간에 배달되도록하기 위해 무엇을 하시겠습니까?

M : 버그를 우선적으로 필터링하고 다시 테스트하세요. 그 동안 어떤 기능이 더 많은 회귀에 직면하고 있는지에 대한 로그를 유지하여 자동화를 시작하십시오. 추가 테스트를 위해 유사하거나 관련된 버그가 다른 사용자에게 제공됩니다.

I : 우선 순위로 표시된 버그가 없다고 가정 해 봅시다. 무엇을 하시겠습니까?

M : 날짜로 필터링하겠습니다. 어떤 종류의 SDLC, 심지어 민첩한 SDLC에서도 핵심 구성 요소가 먼저 개발되고 핵심 버그가 있으면 먼저 수정해야합니다.

I :( 비 승인) 나중에 스프린트에서 매우 중요한 기능이 추가되면 어떻게 되나요? 또한 팀 동료와 자동화 능력을 어떻게 활용 하시겠습니까?

M : 날짜와 함께 테스터로서 나는 날짜까지 제품의 핵심 및 중요한 기능을 알아야하므로이를 염두에두면 각 스프린트의 핵심 영역을 찾을 수 있습니다. 이전과).

I : 버그에 각 스프린트의 타임 라인이 표시되지 않았다고 가정 해 보겠습니다. 무엇을 하시겠습니까?

M : 제품을 출시 할 수없는 중요한 기능을 나타내는 키워드로 버그 목록을 검색하겠습니다. 나는 거기에서 버그를 선택합니다.

I :( 또 다시 비 승인) 키워드를 사용하면 결과가 너무 많아서 하나씩 살펴볼 건가요?

M : (천천히 희망을 잃음) 제목을 살펴보고 결정하겠습니다.

I : 일반적으로 제목은 그렇게 설명 적이 지 않습니다. 어떻게 처리 하시겠습니까?

M : 제품 배송에 대한 결정을 내려야하기 때문에 버그를 조사하는 대신 제품 테스트를 시작하고 내가 직면 한 유사한 버그를 검색 할 것입니다.

I : 그래서 그 많은 버그를 무시 하시겠습니까? 이해 관계자는 동의하지 않을 수 있습니다. (이 후 나는 그것을 완전히 잃어 버리고 계속 휙휙 휙 휙 휙 휙 휙 휙 휙 휙 휙 휙 휙 휙휙 휙 휙 휙 휙 휙 휙 휙 휙 휙휙 휙 휙 휙휙 휙휙 휙휙 휙휙 휙 ...

이것은 Sr SDET의 인터뷰였습니다.

답변

4 KatePaulk Aug 17 2020 at 19:19

다른 답변이 말한 것 외에도 면접관은 팀에 새로 추가 된 귀하가 승패없는 상황을 어떻게 처리할지 찾고 있다고 말하고 싶습니다. 솔직히, 최소한 회사가 과거에 이런 상황에 처해 있었다고 생각합니다. 최악의 경우 (나는 내가 냉소적이라는 것을 자유롭게 인정한다) 비슷한 일이 그 자리를 차지한 사람과 마주하게 될 것이다.

면접관으로서 저는 제가 인터뷰 한 사람에게 다음과 같은 것을 원합니다.

첫째, 이러한 버그, 특히 우선 순위, 심각도 및 위험이 어떻게 구성되어 있는지 알고 싶습니다. 나는 내가이 상황에오고 있다고 가정하고 내가 처음부터 관여 해 왔다고 생각하지 않는다. 왜냐하면 이런 종류의 상황은 어딘가에서 일이 심하게 잘못되었음을 암시하기 때문이다.

버그가 우선 순위, 심각도 및 위험을 포함하는 방식으로 구성되지 않은 경우 다른 테스터, 프로젝트 관리 및 개발과 논의하여 예상 배포에 가장 큰 위험을 초래하는 문제를 파악하고 싶습니다. 데이트.

그러한 조직이 있다면 테스터, 프로젝트 관리 및 개발팀과 이야기하여 가장 위험한 버그를 확인하려고합니다. 이상적으로는 제품이 출시되기 전에 수정해야하는 버그 목록을 작성하는 방법을 찾고 있습니다. 10,000 개의 버그가있는 경우이 목록은 생성하는 데 시간이 걸리며보고 된 버그가 숨기거나 차단하기 때문에 테스터가 찾을 수없는 버그가 없다고 가정합니다.

상황이 얼마나 나쁜지 파악하면 계획대로 애플리케이션을 출시 할 수 있는지 여부를 결정할 수 있습니다. 대부분의 버그가 상대적으로 위험이 낮고 고위험 버그가 합리적으로 쉽게 수정되는 것 같다면 저는 팀을 고위험 버그에 집중하고 프로젝트 관리자 및 다른 팀과 협력하여 최고 위험을 얻습니다. (높은 심각도, 현장에서 발생할 가능성이 가장 높으며 응용 프로그램의 영역을 차단 함) 버그 수정 및 테스트.

제때에 제품을 출시 할 방법을 찾을 수 없다면 프로젝트 관리자와 상사와 대화를 시작하여 견고한 기능의 제한된 베타 출시를 수행하거나 출시를 지연시킬 방법이 있는지 확인합니다. 저는이 직책을 처음 접했기 때문에 릴리스 날짜를 고정시킬 수있는 계약 요건이나 통제 할 수없는 기타 요인이 있는지 알 수 없습니다.

또한 릴리스 후 관련된 모든 팀의 리더들과 함께 그러한 상황이 어떻게 발생했는지, 다시 발생하는 것을 방지하기 위해 취할 수있는 조치와 함께 협력 할 수있는 방법을 파악했습니다. 버그 백 로그를 줄입니다.

이 중 어느 것도 SDET 역할과 관련이 없습니다. 면접관이 SDET가 테스트 리드 역할을 할 것으로 기대한다는 질문에서 분명합니다. 이것은 특히 좋은 일이 아니라고 생각합니다. 솔직히 회사가 회사에서 기대하는 것이 있는지 알고 싶습니다. SDET.

인터뷰는 스트레스가 많은 상황이긴하지만 잠수보다는 옆으로 생각하고 질문의 의미를 살펴 보려고 노력한다는 것을 기억할 가치가 있습니다. 스트레스를 받고 최선을 다하려고하기 때문에하기가 어렵습니다. 하지만 잠시 시간을내어 면접관이 질문에 대해 무엇을 찾고 있는지 정신적으로 물어볼 수 있다면 일반적으로 더 나은 답을 줄 수 있습니다.

1 LewisASellers Aug 17 2020 at 04:14

가장 먼저 떠오르는 것은이 테스트가 이전에 효과가 있었던 적이 있다는 것입니다. 그렇다면 당황하지 마십시오. 코드베이스 또는 테스트 프레임 워크에서 그룹이 실패하게 만드는 무언가가 변경되었습니다. 이를 추적하여 한 번에 수천 개의 실패를 제거 할 수 있는지 확인하십시오. 당신은 여전히 ​​수동으로 다시 지나가는 것들을 읽고 그것들을 다시 확인해야 할 것입니다. 그러나 아마도 그것은 며칠 밖에 걸리지 않을 것입니다.

유사한 작업을 수행하기 전에 확인되지 않은 경우 한 번에 큰 그룹을 수정할 수있는 공통성을 찾으십시오.

그렇지 않으면 소음이 너무 많아서 실패한 중요한 것을 놓칠 수 있습니다.

그 후에는 모든 것을 얻을 수없고 돈벌이 코드 경로에 집중하지 못할 수도 있음을 받아들입니다. 작동해야하는 것 또는 사업이 접 힙니다. 그런 다음 그 중 몇 개를 더 지운 후 격일 또는 세 번에 걸쳐 이전에 언급 한 것과 같은 그룹화 된 실패가 더 이상 있는지 확인하고 몇 개의 그룹을 더 지 웁니다.

참고 : 문제가되는 코드베이스 자체를 수정할 수있는 사람인 SDET의 관점에서이 질문에 대답합니다.

1 PDHide Aug 17 2020 at 03:15

면접관이 테스트 실패가 아닌 버그를 언급 한 경우 ( 테스트 실패 인 경우 @Lewis의 답변 참조

우선 제품에 10000 개의 활성 버그가 있다는 것은 정말 큰 위험 신호입니다.

그리고 그러한 제품을 출시해서는 안됩니다. 하지만 경영진의 결정이 여전히 석방된다면

면접관이 예상했던 대답은 " 심각함 "입니다.

팀은 우선 순위가없는 경우 심각도가 높은 버그를 먼저 수정하는 데 집중해야하며 긴급한 요구 사항이 아니고 실제 비즈니스 로직에 영향을주지 않는 경우에는 낮게 유지해야합니다.

처음에는 연기 테스트 자동화에 집중 한 다음 모든 회귀 도구 모음 자동화를 시작합니다.

버그를 그룹화하고 버그 클러스터링이 발생 하는 위치를 확인 하고 수정이 이루어지면 해당 모듈을 엄격하게 테스트합니다.

출시 전에 모든 연기 테스트 시나리오를 수동으로 테스트합니다 (중요한 비즈니스 로직).

또한 10000 개의 버그가 있으면 이러한 버그가 제품 내의 일부 중요한 버그를 마스킹 하는 결함 마스킹 이 발생할 수 있습니다 .

따라서 수정이 이루어지면 더 중요한 버그를 찾기 위해 모듈에 대해 더 엄격한 테스트를 수행해야합니다.

그래서 내가 인터뷰에 있다면 다음과 같이 대답 할 것입니다.

  1. 어떤 프로젝트에서든 10000 개의 버그는 큰 위험 신호가 될 것이며 적절한 버그 수정 프로세스와 추정이 없었 음을 보여줍니다. 결함 클러스터링과 결함 마스킹에 대해 확실히 걱정할 것입니다. 즉, 대부분의 버그가 단일 모듈에 집중되어있을 가능성이 있으며,이 정도의 버그는 모듈을 엄격하게 수정하고 다시 테스트 한 후에 만 ​​식별되는 다른 중요한 버그를 마스킹 할 수 있습니다. . 그리고 이러한 이유로 출시일을 더 밀어 붙이는 것이 좋습니다.

개발 팀이 버그 수정에 바쁘기 때문에 스모크 테스트 사용 사례와 버그 사용 사례 자동화를 시작할 것입니다. 수정 사항이 도착하면 수동 테스터에게 재 테스트 작업을 할당하고 자체적으로 모듈에 대해 엄격한 임시 테스트를 수행하여 마스킹 된 중요한 버그를 찾습니다.

  1. 우선 순위가 없으면 중요하거나 심각도가 높은 버그를 먼저 재검토하고 버그 수명 시간을 조사하고 버그가 향후 전체 프로세스를 개선하는 데 도움이되도록 오랫동안 수정되지 않은 이유를 이해하는 것은 유휴 상태 일 것입니다.

심각도가 낮은 버그에 대해서는 타임 라인과 이러한 버그가있는 첫 번째 버전을 릴리스할지 여부에 대한 팀 결정을 내려야하지만 필요한 경우 동일한 해결 방법을 문서화해야합니다. 가능한 경우 가능한 수정 사항에 대한 다음 릴리스 날짜도 제공하십시오.

따라서 고위 QA가 되려면 위험 신호를 볼 때 "아니오"를 유지하겠다는 강한 의견을 제시해야합니다. 너무 유연하지 마십시오

LeeJensen Aug 17 2020 at 23:30

질문의 요점이 구체적인 답변을 제공하는 것이라면 여기에 다른 답변이 좋습니다.

그러나 많은 면접관은 당신이 어떻게 생각하는지 또는 질문에 대해 가정하고 있는지 이해하기를 원하기 때문에 구체적인 대답없이 막연한 질문을합니다. 그들은 당신이 구체적인 질문을하기 위해 그들에게 명확한 질문을하기를 원합니다. 이것은 답변을 안내하는 데 도움이됩니다.

시나리오는 당신과 다른 2 명이 테스트 팀으로 구성됩니다. 리더는 자동화를 수행 할 수있는 유일한 사람이고 다른 사람은 수동 테스트 만 수행 할 수 있습니다. 거의 10,000 개의 버그가 발생했으며이 제품이 배송되기까지 4 ~ 5 주가 남았습니다. 제품이 제 시간에 배달되도록하기 위해 무엇을 하시겠습니까?

물어볼 몇 가지 질문 :

  • 수동 QA 테스터는 얼마나 경험이 있습니까?
  • 수동 테스터가이 프로젝트에 경험이 있습니까? 아니면 그들은 프로젝트에 처음입니까?
  • 배송일 전에 10,000 개를 모두 수정해야합니까?
  • 팀에서 사용하는 버그 추적기 소프트웨어가 있습니까? 그렇다면 무엇입니까?
  • 알려진 버그는 어떻게 추적됩니까? 우선 순위, 심각도가 나열되어 있습니까? 기능별로 그룹화 / 태그가 지정됩니까?
  • 현재 소프트웨어에 사용중인 자동화 된 테스트가 있습니까? 그렇다면 단위 테스트, 통합 테스트, UI 테스트는 몇 개입니까? 아니면 4 ~ 5주의 기간 내에 모든 자동화 된 테스트 / 프레임 워크를 처음부터 만들어야합니까?
  • 개발자는 얼마나 많은 테스트를 담당합니까? 단위 / 통합 테스트를 만들고 있습니까?
  • 10,000 개의 버그 UI 버그입니까? 아니면 단위 테스트, 통합 테스트, UI 테스트를 사용하여 테스트 할 수있는 여러 버그가 있습니까?
  • 테스트에 어떤 장치를 사용해야합니까?
  • 사용자와 이해 관계자를 만족시키기 위해 도달해야하는 품질 수준은 무엇입니까? 이해 관계자는 품질을 어떻게 인식합니까?
  • 이해 관계자는 성공적인 프로젝트 시작을 어떻게 결정합니까?
  • done의 팀 정의는 무엇입니까?
  • 팀은 프로젝트 출시 후 버그를 수정할 시간이 있습니까? 아니면 다음 프로젝트로 넘어가나요? 시간이 생기면 시간이 얼마나 남을까요?
  • 팀이 Agile SDLC 또는 Waterfall SDLC를 사용하고 있습니까?

잘 생각한 답변을 제공하는 데 필요한 설명을 얻기 위해 요청할 수있는 질문은 끝이 없습니다.

그리고 위의 자세한 대화에서 면접관은 계획에 수동 테스터를 포함하는 방법에 대한 세부 정보를 계속 요청했습니다. 이것은 면접관이 무엇을 찾고 있는지에 대한 큰 힌트를 제공합니다. 그들은 여러분이이 프로젝트를 직접 테스트해야하는 부담을 완전히 짊어지기를 원하지 않습니다. 그들은 시니어 레벨 SDET / QA 엔지니어로서 당신이 주니어 레벨 테스터 팀을 어떻게 멘토링 / 리더하는지 알고 싶어합니다.

인터뷰는 질문에 대답하는 심문이되어서는 안됩니다. 인터뷰는 질문을 명확히하는 데 도움이되는 모든 것을 물어볼 수있는 대화 여야합니다.