يوضّح هذا المستند كيفية استخدام النصوص البرمجية لبرنامج Robo، وهي اختبارات تُبرمِج مهام ضمان الجودة اليدوية للتطبيقات المتوافقة مع الأجهزة الجوّالة، وتُمكّن من التكامل المستمر (CI) و استراتيجيات اختبار الإطلاق التجريبي. على سبيل المثال، يمكنك استخدام نصوص Robo البرمجية لاختبار تجربة مستخدم شائعة أو تقديم إدخال محدّد لواجهة المستخدم (UI)، مثل اسم مستخدم وكلمة مرور. نصوص Robo البرمجية هي ميزة من ميزات Robo test.
تستخدِم نصوص Robo اختبار Robo
بصفتها محرّك الاختبار. في أبسط أشكاله، يتألّف نص Robo من
تسلسل من إجراءات واجهة المستخدم، مثل إدخال النص "username" ثم النقر على زر OK. يمكن أن تتضمّن نصوص Robo البرمجية أيضًا إجراءات مثل الانتظار
لظهور عنصر والنقر على نقطة معيّنة داخل عنصر
وتنفيذ أوامر shell الخاصة بـ Android Debug Bridge (adb
).
تتمتع نصوص Robo البرمجية بالمزايا التالية مقارنةً بإطارات العمل التقليدية للاختبار:
القدرة | الوصف |
فعّال للغاية | يمكن أن تتحمّل نصوص Robo البرمجية اختلافات هيكلية وسلوكية مهمة بين إصدارات التطبيق ومشاكله. |
مفتوحة | بعد اكتمال نص Robo برمجي، يمكن لاختبار Robo الأساسي المتابعة ومواصلة اختبار التطبيق. يتيح نهج الاختبار المستمر العديد من حالات الاستخدام الرئيسية. على سبيل المثال، يمكنك استخدام نص Robo برمجي لنقل تطبيق إلى حالة معيّنة من خلال تنفيذ عملية تسجيل دخول مخصّصة. |
قابل للتسجيل | لست بحاجة إلى ترميز نصوص Robo البرمجية يدويًا. ويمكن تسجيلها باستخدام أداة تسجيل النصوص البرمجية في Robo في "استوديو Android". لا يتطلّب إنشاء نصوص Robo البرمجية أو تعديلها عادةً أي معرفة بتطوير التطبيقات المتوافقة مع الأجهزة الجوّالة. |
مرن | يمكن للنصوص البرمجية للروبوت التفاعل مع عناصر واجهة المستخدم غير الأصلية الشائعة في الألعاب. |
يتم تشغيل النصوص البرمجية لبرنامج Robo بشكل مشروط أثناء اختبار Robo، ما يتيح للمستخدمين تعزيز سلوك Robo، عادةً لتحقيق تغطية أكبر أو استهداف وظائف معيّنة. على عكس إطارات العمل التقليدية للاختبار، تتيح النصوص البرمجية لبرنامج Robo ما يلي:
- شروط تفعيل مختلفة، على سبيل المثال، اسم حزمة تطبيق معيّن يكون نشطًا (أو لا) أو عنصر معيّن يتم عرضه على الشاشة (أو لا)
- عناصر التحكّم في التنفيذ، مثل الحد الأقصى لعدد عمليات التنفيذ، والأولوية، مرحلة الزحف ذات الصلة
- أنواع الإجراءات غير التقليدية (الشَرطية، أو التي تتجاهل العناصر، أو التي تغلق الشاشة)
ننصحك باستخدام نصوص Robo كلما أمكن ذلك لأنّه يمكن الحفاظ عليها بسهولة. على سبيل المثال، يمكنك استخدام نص Robo برمجي لتنفيذ ما يلي:
- تنقَّل في مسارات العمل المهمة للوصول إلى جوهر وظيفة التطبيق. على سبيل المثال، يمكنك تسجيل الدخول وإعداد حالة التطبيق بعد التشغيل الأول وتسجيل مستخدم جديد.
- يمكنك تركيز Robo على جزء معيّن من التطبيق للاستفادة إلى أقصى حد من وقت اختبار Robo. يوجّه نص Robo برمجي اختبار Robo للوصول إلى الجزء ذي الصلة من التطبيق، حيث يستأنف اختبار Robo الزحف المبرمَج بالكامل.
- نقل التطبيق إلى حالة أو شاشة معيّنة لإجراء تحليل، مثلاً لتحليل رسالة داخل التطبيق أو سياسة خصوصية أو مستوى معيّن من لعبة
- يمكنك إجراء اختبار أدوات قياس شامل، مع اختبار Robo أو بدونه، مع مواصلة الزحف المبرمَج بالكامل بعد اكتمال نص Robo.
استخدِم ميزات أكثر تقدمًا في النصوص البرمجية للروبوت لتنفيذ ما يلي:
- يمكنك تنفيذ الإجراءات قبل أن يبدأ Robo في الزحف إلى التطبيق الذي يتم اختباره أو بعد انتهاء عملية الزحف، على سبيل المثال، تنظيف بيانات التطبيق الذي يتم اختباره قبل عملية الزحف أو تغيير إعدادات الجهاز.
- تغيير جوانب سلوك Robo أثناء الزحف، على وجه الخصوص:
- يمكنك جعل Robo يتجاهل بعض التطبيقات المصغّرة لواجهة المستخدم أو شاشات التطبيقات.
- قدِّم إجراءً مخصّصًا لتنفيذه Robo عند الرجوع من شاشة معيّنة.
- يمكنك جعل Robo ينفذ إجراءات معيّنة عند مواجهة شاشة تطبيق معيّنة أثناء الزحف.
- تخصيص طريقة Robo في الزحف بالكامل على سبيل المثال، استخدِم مزيجًا من الإجراءات الشَرطية وغير الشَرطية لإبقاء التطبيق الذي يتم اختباره في الخلفية طوال عملية الزحف، مع تنفيذ عمليات التحكّم في الجهاز وإغلاق أي مربّعات حوار منبثقة تظهر أثناء التجربة.
يُرجى العِلم أنّ نصوص Robo البرمجية لا تحلّ محلّ جميع أنواع الاختبارات. لا تزال بحاجة إلى اختبارات الوحدة لرصد الأخطاء المنطقية من المستوى المنخفض في تطبيقك، ولا تتطلّب هذه الاختبارات عادةً بيئة Android أو iOS. ننصحك بإضافة اختبارات نصوص Robo إلى اختبارات الأدوات المستهدفة التي يمكن أن تتضمّن تأكيدات محدّدة ومفصّلة حول منطق النشاط التجاري، والتي يمكن التعبير عنها بشكل أفضل في الرمز البرمجي.
الخطوات التالية
للتعرّف على بنية نصوص Robo البرمجية وإمكاناتها واستخداماتها وإجراءاتها، اطّلِع على دليل Robo البرمجي المرجعي.