[Tips] Avoir une console de debug en Web grâce à WCF
Un développeur passe une grande partie de son temps à debugger, il est donc important qu'il ait de bons outils afin de ne pas perdre son temps. On est tous d'accord que lancer Visual Studio en mode debug est très lourd, surtout si l'on veut juste voir la valeur d'une variable, savoir si la fonction x s'éxécute bien avant la fonction y etc ... Il existe cependant une astuce pour éviter de recompiler le site web, cela consiste à attacher le site web à Visual Studio, cela nous fait déjà gagner de nombreuses secondes.
Mais peut-on être plus rapide ? Comment je peux faire pour seulement afficher une variable sans lancer l'artillerie lourde.
- En ASP3, on utilisait des Response.Write un peu partout dans le code.
- En ASP.net, on peut utiliser les Trace.Warn et Trace.Write
Avec ASP.net Ajax, on ne peut pas modifier la réponse HTML, par conséquent ni Response.Write ni Trace.Warn/Trace.Write fonctionne. J'ai longtemps utilisé des Console.Beep, mais au fil du temps, ma machine faisait des bips dans tous les sens et ce n'était pas toujours évident de savoir quel bips correspondait à quel signal.
J'ai récemment trouvé une solution plus fonctionnelle en utilisant un service WCF.
Je me suis donc fait un minuscule service WCF qui ne contient que 2 méthodes :
[ServiceContract]
public interface IDebugService
{
[OperationContract]
void WriteLine(String value);
[OperationContract]
void WriteLineColor(String value, ConsoleColor color);
}
Au niveau du host, j'ai configuré un basicHttpBinding afin de pouvoir faire un "Add Web Reference" plutôt qu'un "Add Service Reference" classique, ceci afin d'éviter de configurer le site pour utiliser .net 3.0.
Enfin dans le site web je peux écrire dans ma console en faisant :
#if DEBUG
new DebugService().WriteLine(s)
#endif
Je profite désormais d'une console de debug sans lancer Visual Studio en Debug ;-)