za dużo by o tym wszystkim pisać.
mogę powiedzieć ze sprawę naprawdę dobrze przedyskutowaliśmy w zespole, a mamy już doświadczenia w budowie api (choć zawsze w nowym projekcie jest coś nowego;) )
testy jednostkowe? zrezygnowaliśmy z nich na rzecz własnego narzędzia.
zadaliśmy sobie pytanie co tak naprawdę nas interesuje.
wyszło nam ze: otrzymany zwrot względem wysłanych parametrów. i właśnie to jest tutaj badane.
np. testy jednostkowe nie wyłapią, czy ktoś zostawił jakiś śmieć w kodzie (np. echo, print_r, etc) my mamy to od ręki.
dodatkowym atutem jest czas, jaki zyskujemy na nie pisaniu unit testow( które i tak nie wystrzegają się błędów logicznych) testy budujemy automatycznie na podstawie pliku konf.
monitorujemy takze czas odpowiedzi serwera, jeśli przekroczymy ustalona wartość - szukamy przyczyn/rozwiazan.
na dłuższą metę - sprawdza się to o wiele lepiej. mamy elastyczne narzędzie, które sprawdza czy to co zmieniliśmy/zrobiliśmy odpowiada naszym założeniom, w razie potrzeby wskazuje miejsce w którym api nie przeszło testów, a nie jest upierdliwe jak unit testy.
decyzja odnosnie przyjecia metody testowania - tez nie byla ad hoc podejmowana, rozwazylismy za i przeciw, i wybralismy najlepsze dla nas rozwiazanie.
komunikacja - na chwile obecną komunikacja po sockecie, w przyszłości byc moze socket + REST, to jeszcze jest do przetestowania/zadecydowania.
format pliku konfiguracji to array (podobnie jak np zend2).
kawalek kodu o ktorym dyskutujemy to:
$function = new \ReflectionClass(get_called_class());
$className = $function->getShortName();
$this->_paramDefault = $this->_config->API->command->{$className};
chyba wystarczajaco jasno dalem odpowiedz ;]
j.