Hi,

Looking at ZnServer >> start and ZnSingleThreadedServer >> stop (as ZnServer >> stop is #subclassResponsibility), I had the impression they are meant to be idempotent.

The start comment is:

        "Start me. I will start listening on my port for incoming HTTP 
connections.
        If I am running, I will first stop and thus effectively restart"

The stop comment is:

        "Stop me. I will stop listening on my port for incoming HTTP 
connections.
        Does nothing when I am not running"

So, it seems like both start and stop try to be safe to be sent twice in a row.

I did a few Transcript prints:

---

1. just stop: is ok.

ZnManagingMultiThreadedServer allInstances do: #stop.
ZnServer managedServers do: #unregister.
Smalltalk garbageCollect.

(ZnServer on: 4998) stop.
(ZnServer on: 4997) stop; stop.

Transcript show: ZnServer managedServers; cr;
        show: ZnManagingMultiThreadedServer allInstances; cr.

==>

an IdentitySet()
an Array(a ZnManagingMultiThreadedServer(stopped 4998) a ZnManagingMultiThreadedServer(stopped 4997))

---

2. start; stop: is ok.

ZnManagingMultiThreadedServer allInstances do: #stop.
ZnServer managedServers do: #unregister.
Smalltalk garbageCollect.

(ZnServer on: 4998) start; stop.
(ZnServer on: 4997) start; stop; stop.

Transcript show: ZnServer managedServers; cr;
        show: ZnManagingMultiThreadedServer allInstances; cr.

==>

an IdentitySet()
an Array(a ZnManagingMultiThreadedServer(stopped 4998) a ZnManagingMultiThreadedServer(stopped 4997))

---

3. register; start; stop: is ok.

ZnManagingMultiThreadedServer allInstances do: #stop.
ZnServer managedServers do: #unregister.
Smalltalk garbageCollect.

(ZnServer on: 4998) register; start; stop.
(ZnServer on: 4997) register; start; stop; stop.

Transcript show: ZnServer managedServers; cr;
        show: ZnManagingMultiThreadedServer allInstances; cr.

==>

an IdentitySet()
an Array(a ZnManagingMultiThreadedServer(stopped 4998) a ZnManagingMultiThreadedServer(stopped 4997))

---

4. start: is ok.

ZnManagingMultiThreadedServer allInstances do: #stop.
ZnServer managedServers do: #unregister.
Smalltalk garbageCollect.

(ZnServer on: 4998) start.
(ZnServer on: 4997) start; start.

Transcript show: ZnServer managedServers; cr;
        show: ZnManagingMultiThreadedServer allInstances; cr.

==>

an IdentitySet()
an Array(a ZnManagingMultiThreadedServer(running 4998) a ZnManagingMultiThreadedServer(running 4997))

5. register; start: is not ok.

ZnManagingMultiThreadedServer allInstances do: #stop.
ZnServer managedServers do: #unregister.
Smalltalk garbageCollect.

(ZnServer on: 4998) register; start.
(ZnServer on: 4997) register; start; start.

Transcript show: ZnServer managedServers; cr;
        show: ZnManagingMultiThreadedServer allInstances; cr.

==>

an IdentitySet(a ZnManagingMultiThreadedServer(running 4998))
an Array(a ZnManagingMultiThreadedServer(running 4998) a ZnManagingMultiThreadedServer(running 4997))

The last case is not idempotent for #start. With one #start, the server is registered, with two #start's, it is not registered.

Shouldn't the last case be idempotent as well?

If it is, it is the bug that should be put into issue tracker?

Herby

Reply via email to