Search test library by skills or roles
⌘ K

About the test:

ソフトウェアシステムの設計オンラインテストでは、シナリオベースのMCQを使用して、機能的および非機能的要件を満たすソフトウェアシステムを設計する習熟度について候補者を評価します。このテストでは、システム要件を特定し、適切なアーキテクチャと設計パターンを選択し、高レベルの設計仕様を作成する候補者の能力を評価します。データベースの設計、データモデリング、システム統合、セキュリティ、パフォーマンスの最適化、品質保証に焦点を当てています。

Covered skills:

  • システムデザイン
  • ネットワークプロトコル
  • 分散システム
  • パフォーマンスの最適化
  • アルゴリズムとデータ構造
  • データベース設計
  • クラウドコンピューティング
  • マイクロサービスアーキテクチャ

Try practice test
9 reasons why
9 reasons why

Adaface System Design Test is the most accurate way to shortlist ソフトウェアエンジニアs



Reason #1

Tests for on-the-job skills

The System Design Online Test helps recruiters and hiring managers identify qualified candidates from a pool of resumes, and helps in taking objective hiring decisions. It reduces the administrative overhead of interviewing too many candidates and saves time by filtering out unqualified candidates at the first step of the hiring process.

The test screens for the following skills that hiring managers look for in candidates:

  • スケーラブルで効率的なシステムアーキテクチャを設計できる
  • 分散システムのパフォーマンスを分析および最適化することができます
  • データベーススキーマの設計と実装に熟練しています
  • ネットワークプロトコルの理解と利用に熟練しています
  • クラウドコンピューティングテクノロジーと概念の専門知識
  • マイクロサービスアーキテクチャの原則に精通しています
  • 複雑な問題を解決するためにアルゴリズムとデータ構造を適用することができます
  • システム設計のパフォーマンスを最適化することができます
  • 大規模な分散システムの操作に経験があります
  • フォールトトレラントで非常に利用可能なシステムの設計に習熟しています
Reason #2

No trick questions

no trick questions

Traditional assessment tools use trick questions and puzzles for the screening, which creates a lot of frustration among candidates about having to go through irrelevant screening assessments.

View sample questions

The main reason we started Adaface is that traditional pre-employment assessment platforms are not a fair way for companies to evaluate candidates. At Adaface, our mission is to help companies find great candidates by assessing on-the-job skills required for a role.

Why we started Adaface
Try practice test
Reason #3

Non-googleable questions

We have a very high focus on the quality of questions that test for on-the-job skills. Every question is non-googleable and we have a very high bar for the level of subject matter experts we onboard to create these questions. We have crawlers to check if any of the questions are leaked online. If/ when a question gets leaked, we get an alert. We change the question for you & let you know.

How we design questions

これらは、10,000以上の質問のライブラリからのわずかなサンプルです。これに関する実際の質問 ソフトウェアシステム設計オンラインテスト グーグルできません.

🧐 Question

Medium

Optimal Data Replication and Consistency in Distributed Systems
Data Consistency
Load Balancing
Fault Tolerance
Try practice test
Consider a distributed e-commerce platform designed to handle high traffic volumes and ensure data consistency across its services. The platform uses a distributed database that replicates data across multiple nodes to increase availability and performance. To balance the load, it employs a load balancer that distributes user requests evenly across these nodes. The system is designed to tolerate the failure of up to two nodes without affecting the platform's overall availability.

Given the critical requirement for strong consistency to prevent issues such as overselling of products, the system uses a consensus algorithm for replication. The database is configured with a replication factor of 5, meaning each piece of data is stored on 5 nodes. For read and write operations to be considered successful, they must be acknowledged by a majority of the nodes involved in the operation.

Assuming all nodes have equal hardware resources and network latency between nodes is negligible, which of the following configurations would best meet the platform's requirements for high availability, performance, and strong consistency?
A: Reads require acknowledgment from 2 nodes, and writes require acknowledgment from 4 nodes.
B: Reads and writes both require acknowledgment from 3 nodes.
C: Reads require acknowledgment from 3 nodes, and writes require acknowledgment from 2 nodes.
D: Reads and writes both require acknowledgment from 4 nodes.
E: Reads require acknowledgment from 1 node, and writes require acknowledgment from 5 nodes.
F: Reads and writes both require acknowledgment from 5 nodes.

Easy

Real-time Vehicle Tracking for Logistics Company
Data Storage
Scalability
Real-time Updates
NoSQL
Try practice test
TransitTrack is a logistics company that needs to store real-time location data (latitude, longitude) of their vehicles as they move across the city. The system should be optimized for fast read and write operations to provide real-time tracking. TransitTrack can tolerate occasional data loss since the vehicle locations are updated frequently. Which of the following data storage solutions should TransitTrack implement for their vehicle tracking system?
A: Utilize a relational database management system (RDBMS) like PostgreSQL with a table indexed on the vehicle_id column for efficient data insertion and retrieval.
B: Implement an in-memory cache like Redis to store the vehicle location data, with the vehicle_id as the key and the latitude-longitude pair as the value.
C: Use a document-oriented database like MongoDB to store the vehicle location data as GeoJSON documents, enabling geospatial querying capabilities.
D: Develop a custom in-memory data structure using a spatial indexing technique like an R-tree to store and query the vehicle location data efficiently.
E: Use a time-series database like InfluxDB to store the vehicle location data along with timestamps, allowing for efficient querying and analysis of historical location data.

Medium

Session stickiness with ELB
Cookies
Try practice test
Johnny Bravo is setting up a new e-commerce store for men's clothing. He set up session stickiness with ELB. But he does not want ELB to manage the cookie, he wants the application to manage the cookie. When the server instance, which is bound to a cookie, crashes what do you expect will happen?
A: ELB will throw an error due to cookie unavailability
B: The response will have a cookie but stickiness will be deleted
C: The session will be sticky and ELB will route requests to another server as ELB keeps replicating the Cookie
D: The session will not be sticky until a new cookie is inserted

Medium

Updating UI after Encoding
UI Design
Decoupling
Try practice test
Imagine you’re a developer at Songbird Inc, working on a music editing app for mobile devices. The app allows users to edit audio clips and export them in various audio formats. Once a user finishes editing a clip, they can choose an output format and initiate the encoding process. This encoding process can take a while depending on the chosen format and the length of the clip. Because it’s a mobile app, you want to avoid freezing the UI while encoding is in progress.

What’s the most appropriate approach to notify the user when the encoding is complete and the exported file is ready?
A: Directly modify the UI elements from within the encoding logic. When encoding finishes, the encoding system can directly tell the UI components to update themselves with the new information (e.g., change a button text to “Export Complete”).
B: Separate the UI update logic from the encoding process. The encoding system should trigger a custom event (e.g., “EncodingFinishedEvent”) upon completion. UI components can listen for this event and update themselves accordingly when it’s received.
C:  Have the UI code continuously check on the encoding status with a loop (often referred to as busy waiting or polling). The loop would keep checking a flag or variable set by the encoding system until the encoding is complete. Once complete, the UI can update itself.
D:  Introduce a central message queue or event bus. The encoding system can publish a message to the message queue upon finishing the task. Separate UI update logic would be subscribed to the queue, listening for relevant messages. When it receives the message about encoding completion, it can update the UI.
E: Let the encoding logic return a callback function to the UI layer when it’s initiated. Once encoding is finished, the encoding system calls back this function, allowing the UI to update itself.

Medium

Decryptor
Strings
Try practice test
What does the following pseudo code print?
 image

Hard

Fibonacci codes
Time Complexity
Pseudo Code
Try practice test
Here are three pseudocodes for calculating the Nth Fibonacci number. Which of the following statements about these codes are true?
 image
A: Time complexity/efficiency of CODE 1, CODE 2, CODE 3 is the same.
B: CODE 2 is more space-efficient than CODE 3.
C: CODE 3 is more space-efficient than CODE 2.
D: CODE 2 is more time-efficient than CODE 1.
E: CODE 3 is more time-efficient than CODE 1.

Hard

Palindrome Test cases
Strings
Try practice test
Go through the following faulty palindrome detection pseudocode and test cases. For which of the test cases would the code return true?
 image
Testcases
A: a
B: aba
C: aaa
D: aac

Medium

Rewards Activities Order
Database Connection
Try practice test
A new popular app tracks the activities performed by its users and grants them rewards based on each individual's total activities performed in a year. This data is maintained in a database table (activitesinfo), with the following columns: userid, totalactivities, reward. This year, due to fundraising activity, the company has decided to further reward its users by enhancing the reward as per the following formula: If reward < = 4000, increase it by 2%, If 4000 < reward <= 8000, increase it by 4%, If reward > 8000, increase it by 6%.
The tech team has written three different scripts to calculate increment for each slab, each script is to run as a separate transaction. Here are the three scripts:
Script 1:
For users with reward <= 4000, set reward = reward * 1.02

Script 2:
For users with reward > 4000 and reward <= 8000, set reward = reward * 1.04

Script 3:
For users with reward > 8000, set reward = reward * 1.06
Each script is to be executed separately. Which of the following options will update the rewards as expected:
A: Execute Script 1 followed by Script 2 followed by Script 3
B: Execute Script 2 followed by Script 3; Script 1 running concurrently throughout
C: Execute Script 3 followed by Script 2; Script 1 running concurrently throughout
D: Execute Script 3 followed by Script 2 followed by Script 1
E: Execute Script 2 followed by Script 3 followed by Script 1

Hard

Graph Traversal and Data Storage
Graph Theory
Algorithm Analysis
Try practice test
Consider the following pseudo code implementing a specific graph traversal algorithm:
 image
What is the order in which the nodes are processed, and which data structure best represents the graph `G` for efficient traversal?

Medium

Implementing a Browser's Back Button
Stack
Data Handling
Try practice test
You are tasked with implementing the "Back" button functionality in a web browser. This feature allows users to return to previously visited web pages in the order they were viewed. The browser maintains a history of URLs in a data structure. Considering the nature of web browsing, where users can go back multiple steps and then navigate to a new page (at which point the future history should be cleared), which data structure and algorithm would best implement this functionality?
A: Use a heap, add the current URL when navigating to a new page, and remove the top element when the back button is used.
B: Use a queue, enqueue the current URL when navigating to a new page, and dequeue when the back button is used.
C: Use a single stack, push the current URL when navigating to a new page, and pop when the back button is used.
D: Use an array, add the current URL to the end when navigating to a new page, and remove the last URL when the back button is used.
E: Use a linked list, add the current URL to the head when navigating to a new page, and move backwards when the back button is used.
F: Use two stacks, push the current URL to the first stack when navigating to a new page, and use the second stack to store the pages when the back button is used.

Easy

Linked List Element Removal
Linked Lists
Element Removal
Try practice test
Consider a singly linked list where each node contains an integer value. Write a function `removeElement` that removes all occurrences of a specific value from the linked list. The function should return the head of the modified linked list.

Pseudo code:
 image
What will be the content of the linked list referred to by `result` after executing the above pseudo code?
🧐 Question🔧 Skill

Medium

Optimal Data Replication and Consistency in Distributed Systems
Data Consistency
Load Balancing
Fault Tolerance

2 mins

System Design
Try practice test

Easy

Real-time Vehicle Tracking for Logistics Company
Data Storage
Scalability
Real-time Updates
NoSQL

2 mins

System Design
Try practice test

Medium

Session stickiness with ELB
Cookies

2 mins

System Design
Try practice test

Medium

Updating UI after Encoding
UI Design
Decoupling

2 mins

System Design
Try practice test

Medium

Decryptor
Strings

2 mins

Technical Aptitude
Try practice test

Hard

Fibonacci codes
Time Complexity
Pseudo Code

2 mins

Technical Aptitude
Try practice test

Hard

Palindrome Test cases
Strings

2 mins

Technical Aptitude
Try practice test

Medium

Rewards Activities Order
Database Connection

3 mins

Technical Aptitude
Try practice test

Hard

Graph Traversal and Data Storage
Graph Theory
Algorithm Analysis

3 mins

Data Structures
Try practice test

Medium

Implementing a Browser's Back Button
Stack
Data Handling

2 mins

Data Structures
Try practice test

Easy

Linked List Element Removal
Linked Lists
Element Removal

2 mins

Data Structures
Try practice test
🧐 Question🔧 Skill💪 Difficulty⌛ Time
Optimal Data Replication and Consistency in Distributed Systems
Data Consistency
Load Balancing
Fault Tolerance
System Design
Medium2 mins
Try practice test
Real-time Vehicle Tracking for Logistics Company
Data Storage
Scalability
Real-time Updates
NoSQL
System Design
Easy2 mins
Try practice test
Session stickiness with ELB
Cookies
System Design
Medium2 mins
Try practice test
Updating UI after Encoding
UI Design
Decoupling
System Design
Medium2 mins
Try practice test
Decryptor
Strings
Technical Aptitude
Medium2 mins
Try practice test
Fibonacci codes
Time Complexity
Pseudo Code
Technical Aptitude
Hard2 mins
Try practice test
Palindrome Test cases
Strings
Technical Aptitude
Hard2 mins
Try practice test
Rewards Activities Order
Database Connection
Technical Aptitude
Medium3 mins
Try practice test
Graph Traversal and Data Storage
Graph Theory
Algorithm Analysis
Data Structures
Hard3 mins
Try practice test
Implementing a Browser's Back Button
Stack
Data Handling
Data Structures
Medium2 mins
Try practice test
Linked List Element Removal
Linked Lists
Element Removal
Data Structures
Easy2 mins
Try practice test
Reason #4

1200+ customers in 75 countries

customers in 75 countries
Brandon

Adaface を使用することで、最初の選考プロセスを 75% 以上最適化することができ、採用担当マネージャーと人材獲得チームの両方にとって貴重な時間を同様に解放することができました。


Brandon Lee, 人々の責任者, Love, Bonito

Try practice test
Reason #5

Designed for elimination, not selection

The most important thing while implementing the pre-employment ソフトウェアシステム設計オンラインテスト in your hiring process is that it is an elimination tool, not a selection tool. In other words: you want to use the test to eliminate the candidates who do poorly on the test, not to select the candidates who come out at the top. While they are super valuable, pre-employment tests do not paint the entire picture of a candidate’s abilities, knowledge, and motivations. Multiple easy questions are more predictive of a candidate's ability than fewer hard questions. Harder questions are often "trick" based questions, which do not provide any meaningful signal about the candidate's skillset.

Science behind Adaface tests
Reason #6

1 click candidate invites

Email invites: You can send candidates an email invite to the ソフトウェアシステム設計オンラインテスト from your dashboard by entering their email address.

Public link: You can create a public link for each test that you can share with candidates.

API or integrations: You can invite candidates directly from your ATS by using our pre-built integrations with popular ATS systems or building a custom integration with your in-house ATS.

invite candidates
Reason #7

Detailed scorecards & benchmarks

サンプルスコアカードを表示します
Try practice test
Reason #8

High completion rate

Adaface tests are conversational, low-stress, and take just 25-40 mins to complete.

This is why Adaface has the highest test-completion rate (86%), which is more than 2x better than traditional assessments.

test completion rate
Reason #9

Advanced Proctoring


Learn more

About the System Design Assessment Test

Why you should use Pre-employment System Design Online Test?

The ソフトウェアシステム設計オンラインテスト makes use of scenario-based questions to test for on-the-job skills as opposed to theoretical knowledge, ensuring that candidates who do well on this screening test have the relavant skills. The questions are designed to covered following on-the-job aspects:

  • システム設計の概念と原則の習熟度
  • スケーラブルおよび分散システムを設計する機能
  • さまざまなネットワークプロトコルとその実装に関する知識
  • データベースの設計と最適化手法の経験
  • クラウドコンピューティングプラットフォームとサービスに精通しています
  • アルゴリズムとデータ構造の強力な理解
  • パフォーマンスの最適化とチューニングに関する専門知識
  • マイクロサービスアーキテクチャの実践的な経験
  • 分散システムとその課題の理解
  • システムセキュリティと脅威から保護することに関する詳細な知識

Once the test is sent to a candidate, the candidate receives a link in email to take the test. For each candidate, you will receive a detailed report with skills breakdown and benchmarks to shortlist the top candidates from your pool.

What topics are covered in the System Design Online Test?

  • システム設計

    システム設計には、特定の要件を満たすためにシステムのアーキテクチャ、コンポーネント、およびインターフェイスを定義するプロセスが含まれます。大量のデータとユーザートラフィックを効率的に処理できるスケーラブルで信頼性が高く、保守可能なシステムの設計に焦点を当てています。効率的なアルゴリズムと最適なストレージと検索のためのデータの整理。このスキルの習熟度は、最小限のリソースで最適に実行されるコードを書くコードを書く能力と支援を強化するため、重要です。ネットワーク内のデバイス間の通信。ネットワークプロトコルを理解することは、データを効果的に交換し、安全で信頼できる通信を確保できるシステムを設計するために不可欠です。異なるエンティティ間の関係。最適化されたストレージと検索のためにデータの整合性、クエリ、インデックス作成をサポートする効率的なスキーマを作成することを伴います。ゴール。このスキルの習熟度は、一貫性、フォールトトレランス、負荷分散などの概念を理解することを保証するため重要です。これらは、スケーラブルで回復力のあるアプリケーションを構築する際の基本です。

  • クラウドコンピューティング

    クラウドコンピューティングには、インターネット上でオンデマンドコンピューティングリソースを提供することが含まれます。このスキルの習熟度により、クラウドベースのサービスとインフラストラクチャの効率的な利用により、スケーラビリティ、コスト最適化、アプリケーションのパフォーマンスの向上につながります。システムの速度と効率。このスキルの習熟度は、ボトルネックの特定と解決、アルゴリズムの最適化、冗長操作の排除に役立ち、実行の速度とリソース消費の削減につながります。アプリケーションは、小さな、ゆるく結合されたサービスのコレクションとして構築されています。このスキルの習熟度により、異なるコンポーネントを個別に展開、変更、およびスケーリングする際のスケーラビリティ、フォールトトレランス、柔軟性が可能になります。

  • Full list of covered topics

    The actual topics of the questions in the final test will depend on your job description and requirements. However, here's a list of topics you can expect the questions for ソフトウェアシステム設計オンラインテスト to be based on.

    システムデザイン
    ロードバランシング
    キャッシング
    スケーラビリティ
    データベースシェルディング
    一貫性モデル
    分散ファイルシステム
    MapReduce
    キャップ定理
    コンセンサスアルゴリズム
    ネットワークプロトコル
    TCP/IP
    http
    DNS
    WebSockets
    データベース設計
    リレーショナルデータベース
    NOSQLデータベース
    インデックス付け
    クエリ最適化
    酸トランザクション
    分散システム
    メッセージキュー
    最終的な一貫性
    複製
    フォールトトレランス
    分散ロック
    クラウドコンピューティング
    仮想化
    コンテナ
    サーバーレスコンピューティング
    弾性
    マイクロサービスアーキテクチャ
    サービスの発見
    APIゲートウェイ
    イベント主導のアーキテクチャ
    回路ブレーカーパターン
    パフォーマンスの最適化
    負荷テスト
    プロファイリング
    キャッシュ戦略
    分散トレース
    スケーラビリティテスト
    マイクロサービスオーケストレーション
    監視と警告
    マイクロサービスセキュリティ
    アルゴリズムとデータ構造
    ソートアルゴリズム
    検索アルゴリズム
    グラフアルゴリズム
    ツリーデータ構造
    ハッシュ
    動的プログラミング
    ネットワークフロー
    クラウドコンピューティングの基礎
    パフォーマンス監視
    セキュリティベストプラクティス
    APIデザイン
    サービスレベルアグリーメント
    コンテナ化技術
    継続的な統合と配信
Try practice test

What roles can I use the System Design Online Test for?

  • ソフトウェアエンジニア
  • システムアーキテクト
  • 技術的なリード
  • フルスタック開発者
  • DevOpsエンジニア
  • データベース管理者
  • ネットワーク管理者
  • クラウドエンジニア
  • セキュリティアナリスト
  • パフォーマンスエンジニア

How is the System Design Online Test customized for senior candidates?

For intermediate/ experienced candidates, we customize the assessment questions to include advanced topics and increase the difficulty level of the questions. This might include adding questions on topics like

  • ソフトウェアアーキテクチャパターンのしっかりした理解
  • アプリケーションのパフォーマンスを分析および最適化する機能
  • 大規模なデータ処理システムの操作の経験
  • キャッシュメカニズムと戦略に関する知識
  • フォールトトレラントシステムを設計および実装する能力
  • コンテナ化およびオーケストレーションテクノロジーの習熟度
  • 分散データベースの設計と管理に関する専門知識
  • イベント駆動型および非同期アーキテクチャの理解
  • 複雑なシステムの問題をトラブルシューティングおよびデバッグする機能
  • 非常に利用可能でスケーラブルなサービスの設計の経験
Singapore government logo

採用担当者は、パネル面接中に尋ねる専門的な質問を通じて、どの候補者がより良いスコアを持っているかを判断し、スコアがそれほど高くない候補者と区別できると感じました。彼らです 非常に満足 Adaface のスクリーニングで最終候補者リストに選ばれた候補者の質を重視します。


85%
スクリーニング時間の短縮

System Design Hiring Test よくある質問

複数のスキルを1つのカスタム評価に組み合わせることはできますか?

そのとおり。カスタム評価は、職務内容に基づいて設定され、指定したすべての必須スキルに関する質問が含まれます。

アンチチートまたは監督の機能はありますか?

次のアンチチート機能があります。

  • グーグル不可能な質問
  • IP監督
  • Webの提案
  • ウェブカメラの監督
  • 盗作の検出
  • 安全なブラウザ

[プロクチャリング機能](https://www.adaface.com/proctoring)の詳細をご覧ください。

テストスコアを解釈するにはどうすればよいですか?

留意すべき主なことは、評価が選択ツールではなく排除ツールであることです。スキル評価が最適化され、技術的にその役割の資格がない候補者を排除するのに役立ちます。これは、役割の最良の候補者を見つけるのに役立つために最適化されていません。したがって、評価を使用する理想的な方法は、しきい値スコア(通常は55%、ベンチマークを支援します)を決定し、インタビューの次のラウンドのしきい値を超えてスコアを上回るすべての候補者を招待することです。

このテストを使用できますか?

各ADAFACE評価は、職務記述書/理想的な候補者のペルソナにカスタマイズされます(当社の主題の専門家は、10000以上の質問のライブラリからあなたの評価に適切な質問を選択します)。この評価は、あらゆる経験レベルでカスタマイズできます。

すべての候補者は同じ質問を受け取りますか?

私は候補者です。練習テストを試すことはできますか?

いいえ。残念ながら、現時点では練習テストをサポートしていません。ただし、[サンプルの質問](https://www.adaface.com/questions)を使用するには、練習できます。

このテストを使用するコストはいくらですか?

無料トライアルを受けることはできますか?

私はちょうど有料プランに移りました。カスタム評価をリクエストするにはどうすればよいですか?

customers across world
Join 1200+ companies in 75+ countries.
今日、最も候補者のフレンドリーなスキル評価ツールをお試しください。
g2 badges
Ready to use the Adaface ソフトウェアシステム設計オンラインテスト?
Ready to use the Adaface ソフトウェアシステム設計オンラインテスト?
私たちとしゃべる
ada
Ada
● Online
✖️