Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Script für einen SpeedTest über speedtest.net

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Script für einen SpeedTest über speedtest.net

    This topic has been deleted. Only users with topic management privileges can see it.
    • sigi234
      sigi234 Forum Testing Most Active @sveni_lee last edited by sigi234

      @sveni_lee

      Ich glaube da liegt der Fehler bei mir:

      javascript.0	2019-03-01 10:30:00.119	error	konnte nicht gefunden werden.
      javascript.0	2019-03-01 10:30:00.119	error	script.js.Test.Speedtest: Der Befehl "speed-test" ist entweder falsch geschrieben oder
      
      S 1 Reply Last reply Reply Quote 0
      • S
        sveni_lee @sigi234 last edited by

        @sigi234

        hast Du mall eine Messung mit dem Handy gemacht? nur zum Vergleich. ich habe mit dem Speedtest extreme Schwankungen seit zwei/drei Wochen.

        1 Reply Last reply Reply Quote 0
        • S
          sveni_lee last edited by

          Ich habe jetzt mal speed-deinstalliert und noch einmal neu installiert und jetzt bekomme ih auch wieder vernüftige Server und vor alles bessere Werte ☺

          1 Reply Last reply Reply Quote 0
          • T
            tempestas last edited by

            Ich habe, da auch bei mir die Daten überhaupt nicht mehr sinnig waren, das Paket erst deinstalliert udn dann neu installiert.

            jetz bekomme ich nur noch

            avascript.0	2019-03-29 08:52:33.522	error	2
            javascript.0	2019-03-29 08:52:33.522	error	script.js.common.System.Internet: Speedtest Daten konnten nicht abgefragt werden
            javascript.0	2019-03-29 08:52:33.522	error	at /usr/lib/node_modules/speed-test/node_modules/speedtest-net/index.js:329:16
            javascript.0	2019-03-29 08:52:33.522	error	at /usr/lib/node_modules/speed-test/node_modules/speedtest-net/index.js:97:16
            javascript.0	2019-03-29 08:52:33.522	error	at /usr/lib/node_modules/speed-test/node_modules/speedtest-net/index.js:364:11
            javascript.0	2019-03-29 08:52:33.522	error	at /usr/lib/node_modules/speed-test/node_modules/speedtest-net/index.js:660:7
            javascript.0	2019-03-29 08:52:33.522	error	at startDownload (/usr/lib/node_modules/speed-test/node_modules/speedtest-net/index.js:683:10)
            javascript.0	2019-03-29 08:52:33.522	error	at EventEmitter.emit (events.js:188:7)
            javascript.0	2019-03-29 08:52:33.522	error	at emitOne (events.js:96:13)
            javascript.0	2019-03-29 08:52:33.522	error	at EventEmitter.g (events.js:292:16)
            javascript.0	2019-03-29 08:52:33.522	error	at EventEmitter.st.once.server (/usr/lib/node_modules/speed-test/cli.js:108:12)
            javascript.0	2019-03-29 08:52:33.522	error	at map (/usr/lib/node_modules/speed-test/cli.js:93:16)
            javascript.0	2019-03-29 08:52:33.522	error	TypeError: URL is not a constructor
            javascript.0	2019-03-29 08:52:33.522	error	^
            javascript.0	2019-03-29 08:52:33.522	error	server.host = new URL(server.url).host;
            javascript.0	2019-03-29 08:52:33.522	error	script.js.common.System.Internet: /usr/lib/node_modules/speed-test/cli.js:93
            

            HELP pls? Ich rate mal, dass irgendwas mit der installation nicht korrekt war, aber ich habe null Ahnung, was Linux angeht. (ich tippe immer nur ab, was ich in Anleitungen finde)

            1 Reply Last reply Reply Quote 0
            • Nashra
              Nashra Most Active Forum Testing last edited by Nashra

              Hey, install vom speed-test hat funktioniert. Script läuft auch, hat alle datenpunkte angelegt und
              es werden auch Daten eingetragen. Nur im Log haut es mit Warn voll.

              javascript.0 2019-03-29 12:00:46.670 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
              javascript.0 2019-03-29 12:00:46.670 warn at maybeClose (internal/child_process.js:915:16)
              javascript.0 2019-03-29 12:00:46.669 warn at ChildProcess.emit (events.js:214:7)
              javascript.0 2019-03-29 12:00:46.669 warn at emitTwo (events.js:126:13)
              javascript.0 2019-03-29 12:00:46.669 warn at ChildProcess.exithandler (child_process.js:273:7)
              javascript.0 2019-03-29 12:00:46.669 warn at script.js.Meine_Geräte.Speedtest:66:1
              javascript.0 2019-03-29 12:00:46.669 warn at writeDP (script.js.Meine_Geräte.Speedtest:147:4)
              javascript.0 2019-03-29 12:00:46.669 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
              javascript.0 2019-03-29 12:00:46.669 warn Wrong type of javascript.0.Status.Speed-Test.data.server.id: "string". Please fix, while deprecated and will not work in next versions.
              javascript.0 2019-03-29 12:00:46.669 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
              javascript.0 2019-03-29 12:00:46.668 warn at maybeClose (internal/child_process.js:915:16)
              javascript.0 2019-03-29 12:00:46.668 warn at ChildProcess.emit (events.js:214:7)
              javascript.0 2019-03-29 12:00:46.668 warn at emitTwo (events.js:126:13)
              javascript.0 2019-03-29 12:00:46.668 warn at ChildProcess.exithandler (child_process.js:273:7)
              javascript.0 2019-03-29 12:00:46.668 warn at script.js.Meine_Geräte.Speedtest:66:1
              javascript.0 2019-03-29 12:00:46.668 warn at writeDP (script.js.Meine_Geräte.Speedtest:145:4)
              javascript.0 2019-03-29 12:00:46.668 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
              javascript.0 2019-03-29 12:00:46.668 warn State "javascript.0.Status.Speed-Test.data.server.distanceMI" not found
              javascript.0 2019-03-29 12:00:46.668 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
              javascript.0 2019-03-29 12:00:46.668 warn at maybeClose (internal/child_process.js:915:16)
              javascript.0 2019-03-29 12:00:46.667 warn at ChildProcess.emit (events.js:214:7)
              javascript.0 2019-03-29 12:00:46.667 warn at emitTwo (events.js:126:13)
              javascript.0 2019-03-29 12:00:46.667 warn at ChildProcess.exithandler (child_process.js:273:7)
              javascript.0 2019-03-29 12:00:46.667 warn at script.js.Meine_Geräte.Speedtest:66:1
              javascript.0 2019-03-29 12:00:46.667 warn at writeDP (script.js.Meine_Geräte.Speedtest:139:4)
              javascript.0 2019-03-29 12:00:46.667 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
              javascript.0 2019-03-29 12:00:46.667 warn Wrong type of javascript.0.Status.Speed-Test.data.server.lon: "number". Please fix, while deprecated and will not work in next versions.
              javascript.0 2019-03-29 12:00:46.667 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
              javascript.0 2019-03-29 12:00:46.667 warn at maybeClose (internal/child_process.js:915:16)
              javascript.0 2019-03-29 12:00:46.662 warn at ChildProcess.emit (events.js:214:7)
              javascript.0 2019-03-29 12:00:46.662 warn at emitTwo (events.js:126:13)
              javascript.0 2019-03-29 12:00:46.662 warn at ChildProcess.exithandler (child_process.js:273:7)
              javascript.0 2019-03-29 12:00:46.662 warn at script.js.Meine_Geräte.Speedtest:66:1
              javascript.0 2019-03-29 12:00:46.662 warn at writeDP (script.js.Meine_Geräte.Speedtest:138:4)
              javascript.0 2019-03-29 12:00:46.662 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
              javascript.0 2019-03-29 12:00:46.661 warn Wrong type of javascript.0.Status.Speed-Test.data.server.lat: "number". Please fix, while deprecated and will not work in next versions.
              javascript.0 2019-03-29 12:00:46.661 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
              javascript.0 2019-03-29 12:00:46.661 warn at maybeClose (internal/child_process.js:915:16)
              javascript.0 2019-03-29 12:00:46.661 warn at ChildProcess.emit (events.js:214:7)
              javascript.0 2019-03-29 12:00:46.661 warn at emitTwo (events.js:126:13)
              javascript.0 2019-03-29 12:00:46.661 warn at ChildProcess.exithandler (child_process.js:273:7)
              javascript.0 2019-03-29 12:00:46.661 warn at script.js.Meine_Geräte.Speedtest:66:1
              javascript.0 2019-03-29 12:00:46.661 warn at writeDP (script.js.Meine_Geräte.Speedtest:135:4)
              javascript.0 2019-03-29 12:00:46.661 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
              javascript.0 2019-03-29 12:00:46.661 warn Wrong type of javascript.0.Status.Speed-Test.data.client.ispulavg: "undefined". Please fix, while deprecated and will not work in next versions.
              javascript.0 2019-03-29 12:00:46.660 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
              javascript.0 2019-03-29 12:00:46.660 warn at maybeClose (internal/child_process.js:915:16)
              javascript.0 2019-03-29 12:00:46.660 warn at ChildProcess.emit (events.js:214:7)
              javascript.0 2019-03-29 12:00:46.660 warn at emitTwo (events.js:126:13)
              javascript.0 2019-03-29 12:00:46.660 warn at ChildProcess.exithandler (child_process.js:273:7)
              javascript.0 2019-03-29 12:00:46.660 warn at script.js.Meine_Geräte.Speedtest:66:1
              javascript.0 2019-03-29 12:00:46.660 warn at writeDP (script.js.Meine_Geräte.Speedtest:130:4)
              javascript.0 2019-03-29 12:00:46.660 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
              javascript.0 2019-03-29 12:00:46.660 warn Wrong type of javascript.0.Status.Speed-Test.data.client.lon: "number". Please fix, while deprecated and will not work in next versions.
              javascript.0 2019-03-29 12:00:46.659 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
              javascript.0 2019-03-29 12:00:46.659 warn at maybeClose (internal/child_process.js:915:16)
              javascript.0 2019-03-29 12:00:46.659 warn at ChildProcess.emit (events.js:214:7)
              javascript.0 2019-03-29 12:00:46.659 warn at emitTwo (events.js:126:13)
              javascript.0 2019-03-29 12:00:46.659 warn at ChildProcess.exithandler (child_process.js:273:7)
              javascript.0 2019-03-29 12:00:46.659 warn at script.js.Meine_Geräte.Speedtest:66:1
              javascript.0 2019-03-29 12:00:46.659 warn at writeDP (script.js.Meine_Geräte.Speedtest:129:4)
              javascript.0 2019-03-29 12:00:46.659 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
              javascript.0 2019-03-29 12:00:46.658 warn Wrong type of javascript.0.Status.Speed-Test.data.client.lat: "number". Please fix, while deprecated and will not work in next versions.

              Wie bekomme ich die Warn weg 😕

              A 1 Reply Last reply Reply Quote 0
              • A
                aleks-83 @Nashra last edited by aleks-83

                @cybertron
                Ich habe das gleiche Problem wie @Nashra , wie kann man das beseitigen?
                Von Hand die Typen der betroffenen Datenpunkte ändern?

                javascript.0 09.05.2019 10:30 info Stop script script.js.FritzBox.speedtest
                javascript.0 2019-05-09 10:30:00.028 info script.js.FritzBox.speedtest: exec: speed-test --json --verbose
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.server.id, state="17392")
                javascript.0 09.05.2019 10:29 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
                javascript.0 09.05.2019 10:29 warn at maybeClose (internal/child_process.js:915:16)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.emit (events.js:214:7)
                javascript.0 09.05.2019 10:29 warn at emitTwo (events.js:126:13)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.exithandler (child_process.js:273:7)
                javascript.0 09.05.2019 10:29 warn at script.js.FritzBox.speedtest:45:1
                javascript.0 09.05.2019 10:29 warn at writeDP (script.js.FritzBox.speedtest:130:4)
                javascript.0 09.05.2019 10:29 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
                javascript.0 09.05.2019 10:29 warn Wrong type of javascript.0.Status.Speed-Test.data.server.id: "string". Please fix, while deprecated and will not work in next versions.
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.server.ping, state=25.1)
                javascript.0 09.05.2019 10:29 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
                javascript.0 09.05.2019 10:29 warn at maybeClose (internal/child_process.js:915:16)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.emit (events.js:214:7)
                javascript.0 09.05.2019 10:29 warn at emitTwo (events.js:126:13)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.exithandler (child_process.js:273:7)
                javascript.0 09.05.2019 10:29 warn at script.js.FritzBox.speedtest:45:1
                javascript.0 09.05.2019 10:29 warn at writeDP (script.js.FritzBox.speedtest:128:4)
                javascript.0 09.05.2019 10:29 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
                javascript.0 09.05.2019 10:29 warn State "javascript.0.Status.Speed-Test.data.server.distanceMI" not found
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.server.distance, state=135.4)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.server.sponsor, state="myLoc managed IT AG")
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.server.cc, state="DE")
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.server.country, state="Germany")
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.server.location, state="Dusseldorf")
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.server.lon, state=XXXX)
                javascript.0 09.05.2019 10:29 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
                javascript.0 09.05.2019 10:29 warn at maybeClose (internal/child_process.js:915:16)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.emit (events.js:214:7)
                javascript.0 09.05.2019 10:29 warn at emitTwo (events.js:126:13)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.exithandler (child_process.js:273:7)
                javascript.0 09.05.2019 10:29 warn at script.js.FritzBox.speedtest:45:1
                javascript.0 09.05.2019 10:29 warn at writeDP (script.js.FritzBox.speedtest:122:4)
                javascript.0 09.05.2019 10:29 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
                javascript.0 09.05.2019 10:29 warn Wrong type of javascript.0.Status.Speed-Test.data.server.lon: "number". Please fix, while deprecated and will not work in next versions.
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.server.lat, state=XXXXX)
                javascript.0 09.05.2019 10:29 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
                javascript.0 09.05.2019 10:29 warn at maybeClose (internal/child_process.js:915:16)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.emit (events.js:214:7)
                javascript.0 09.05.2019 10:29 warn at emitTwo (events.js:126:13)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.exithandler (child_process.js:273:7)
                javascript.0 09.05.2019 10:29 warn at script.js.FritzBox.speedtest:45:1
                javascript.0 09.05.2019 10:29 warn at writeDP (script.js.FritzBox.speedtest:121:4)
                javascript.0 09.05.2019 10:29 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
                javascript.0 09.05.2019 10:29 warn Wrong type of javascript.0.Status.Speed-Test.data.server.lat: "number". Please fix, while deprecated and will not work in next versions.
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.server.host, state="ookla.myloc.de:8080")
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.client.ispulavg, state=undefined)
                javascript.0 09.05.2019 10:29 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
                javascript.0 09.05.2019 10:29 warn at maybeClose (internal/child_process.js:915:16)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.emit (events.js:214:7)
                javascript.0 09.05.2019 10:29 warn at emitTwo (events.js:126:13)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.exithandler (child_process.js:273:7)
                javascript.0 09.05.2019 10:29 warn at script.js.FritzBox.speedtest:45:1
                javascript.0 09.05.2019 10:29 warn at writeDP (script.js.FritzBox.speedtest:117:4)
                javascript.0 09.05.2019 10:29 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
                javascript.0 09.05.2019 10:29 warn Wrong type of javascript.0.Status.Speed-Test.data.client.ispulavg: "undefined". Please fix, while deprecated and will not work in next versions.
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.client.ispdlavg, state=0)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.client.rating, state=0)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.client.isprating, state=3.7)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.client.isp, state="Deutsche Telekom AG")
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.client.lon, state=8.6009)
                javascript.0 09.05.2019 10:29 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
                javascript.0 09.05.2019 10:29 warn at maybeClose (internal/child_process.js:915:16)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.emit (events.js:214:7)
                javascript.0 09.05.2019 10:29 warn at emitTwo (events.js:126:13)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.exithandler (child_process.js:273:7)
                javascript.0 09.05.2019 10:29 warn at script.js.FritzBox.speedtest:45:1
                javascript.0 09.05.2019 10:29 warn at writeDP (script.js.FritzBox.speedtest:112:4)
                javascript.0 09.05.2019 10:29 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
                javascript.0 09.05.2019 10:29 warn Wrong type of javascript.0.Status.Speed-Test.data.client.lon: "number". Please fix, while deprecated and will not work in next versions.
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.client.lat, state=XXXX)
                javascript.0 09.05.2019 10:29 warn at Process.ChildProcess._handle.onexit (internal/child_process.js:209:5)
                javascript.0 09.05.2019 10:29 warn at maybeClose (internal/child_process.js:915:16)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.emit (events.js:214:7)
                javascript.0 09.05.2019 10:29 warn at emitTwo (events.js:126:13)
                javascript.0 09.05.2019 10:29 warn at ChildProcess.exithandler (child_process.js:273:7)
                javascript.0 09.05.2019 10:29 warn at script.js.FritzBox.speedtest:45:1
                javascript.0 09.05.2019 10:29 warn at writeDP (script.js.FritzBox.speedtest:111:4)
                javascript.0 09.05.2019 10:29 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
                javascript.0 09.05.2019 10:29 warn Wrong type of javascript.0.Status.Speed-Test.data.client.lat: "number". Please fix, while deprecated and will not work in next versions.
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.client.ip, state="XXXXXXX")
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.speeds.orginalUpload, state=1327716)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.speeds.orginalDownload, state=6599160)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.speeds.upload, state=12.098)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.data.speeds.download, state=59.92)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.upload, state=12.1)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.download, state=59.9)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.ping, state=25)
                javascript.0 09.05.2019 10:29 info script.js.FritzBox.speedtest: setForeignState(id=javascript.0.Status.Speed-Test.json, state="{"ping":25,"download":59.9,"upload":12.1,"data":{"speeds":{"download":59.92,"upload":12.098,
                javascript.0 2019-05-09 10:29:00.027 info script.js.FritzBox.speedtest: exec: speed-test --json --verbose

                paul53 1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @aleks-83 last edited by

                  @aleks-83 sagte:

                  Von Hand die Typen der betroffenen Datenpunkte ändern?

                  Ja
                  .id von "number" in "string"
                  .lat, .long von "string" bzw. "long" in "number"

                  1 Reply Last reply Reply Quote 1
                  • A
                    aleks-83 last edited by aleks-83

                    OK, habe ich erledigt. Danke.
                    Es gibt nur noch die Fehlermeldung zum

                    Wrong type of javascript.0.Status.Speed-Test.data.client.ispulavg: "undefined".
                    

                    Obwohl dieser Punkt auf number steht.

                    Und, kleiner Tipp: im Skript hast du 1x anstatt distanceMi, distanceMI verwendet.

                    Wenn ich alle Fehlermeldungen weg bekommen habe, stelle ich das Skript nochmal ein, wenn das für dich OK ist!?

                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @aleks-83 last edited by

                      @aleks-83 sagte:

                      wenn das für dich OK ist!?

                      Das Skript ist nicht von mir.

                      Wrong type of javascript.0.Status.Speed-Test.data.client.ispulavg: "undefined".
                      

                      "undefined" bedeutet, dass kein Wert vorhanden ist. Ist das immer so oder hat der Datenpunkt einen sinnvollen Wert (Zahl) ?

                      1 Reply Last reply Reply Quote 0
                      • A
                        aleks-83 last edited by

                        Nein, als Wert steht "null MBit/s" drin.
                        Also keine 0 als Zahl, sondern "null"

                        paul53 1 Reply Last reply Reply Quote 0
                        • paul53
                          paul53 @aleks-83 last edited by

                          @aleks-83 sagte:

                          als Wert steht "null MBit/s" drin

                          Dann ist folgende Zeile falsch:

                          var Client_ispulavg = objects.data.client.ispulavg.varvalue;
                          
                          1 Reply Last reply Reply Quote 0
                          • A
                            aleks-83 last edited by aleks-83

                            OK,
                            habe mal das .varvalue entfernt, wie bei dem ispdlavg darüber auch.
                            Jetzt läuft es fehlerfrei.

                            @cybertron
                            Wenn ich dein Skript hier "korrigiert" einstellen darf, sag bitte Bescheid.
                            Ansonsten gebe ich es gerne als PN raus.

                            paul53 Negalein sigi234 K 4 Replies Last reply Reply Quote 0
                            • paul53
                              paul53 @aleks-83 last edited by

                              @aleks-83 sagte:

                              Wenn ich dein Skript hier "korrigiert" einstellen darf, sag bitte Bescheid.

                              Das ist nicht mein Skript ! Von mir kommen lediglich Vorschläge zur Korrektur.

                              A 1 Reply Last reply Reply Quote 0
                              • Negalein
                                Negalein Global Moderator @aleks-83 last edited by

                                @aleks-83 sagte in Script für einen SpeedTest über speedtest.net:

                                Ansonsten gebe ich es gerne als PN raus.

                                würde mich freuen 🙂

                                1 Reply Last reply Reply Quote 0
                                • A
                                  aleks-83 @paul53 last edited by

                                  @paul53
                                  Ich habe ja auch extra Cybertron angesprochen. 😉

                                  1 Reply Last reply Reply Quote 0
                                  • sigi234
                                    sigi234 Forum Testing Most Active @aleks-83 last edited by

                                    @aleks-83 sagte in Script für einen SpeedTest über speedtest.net:

                                    Ansonsten gebe ich es gerne als PN raus.

                                    Mich auch...........☺

                                    1 Reply Last reply Reply Quote 0
                                    • K
                                      Kueppert @aleks-83 last edited by

                                      @aleks-83 stell es sich einfach hier ein mit den Hinweis, dass du Korrekturen von einem vorhandenen Skript vorgenommen hast, dann haben alle etwas von, ich zb auch. Das Skript funktioniert bei mir auch nicht mehr leider 🙂

                                      1 Reply Last reply Reply Quote 0
                                      • A
                                        aleks-83 last edited by aleks-83

                                        Sorry, etwas verspätet...

                                        Hier mein korrigiertes Skript: (Original von @cybertron)

                                        var logging = false;
                                        var instanz = 'javascript.0';  instanz = instanz + '.';
                                        var pfad =     'Status.Speed-Test.';
                                        var cronStr         = "0 * * * *";
                                        var forceCreation   = false;
                                        
                                        createState('Status.Speed-Test.json');
                                        createState('Status.Speed-Test.ping',{name: 'Ping',desc: 'Ping',type: 'number'}); 																// 118
                                        createState('Status.Speed-Test.download',{name: 'Download',desc: 'Downloadgeschwindigkeit (Mbit/s)',type: 'number',unit:'Mbit/s'});                   					//	2.2
                                        createState('Status.Speed-Test.upload',{name: 'Upload',desc: 'Uploadgeschwindigkeit (Mbit/s)',type: 'number',unit:'Mbit/s'});                         					//	2.2
                                        
                                        createState('Status.Speed-Test.data.speeds.download',{name: 'Download',desc: 'Downloadgeschwindigkeit (Mbit/s)',type: 'number',unit:'Mbit/s'}); 							//	2.179
                                        createState('Status.Speed-Test.data.speeds.upload',{name: 'Upload',desc: 'Uploadgeschwindigkeit (Mbit/s)',type: 'number',unit:	'Mbit/s'});          					//	2.209
                                        createState('Status.Speed-Test.data.speeds.orginalDownload',{name: 'OrginalDownload',desc: 'Downloadgeschwindigkeit (bit/s)',type: 'number',unit:'bit/s'});  			//	239941
                                        createState('Status.Speed-Test.data.speeds.orginalUpload',{name: 'OrginalUpload',desc: 'Uploadgeschwindigkeit (bit/s)',type: 'number',unit:'bit/s'});        			//	242389
                                        
                                        createState('Status.Speed-Test.data.client.ip',{name: 'IP',desc: 'Öffentliche IP-Adresse',type: 'string'});                  													//	xxx.xxx.xxx.xxx
                                        createState('Status.Speed-Test.data.client.lat',{name: 'Latitude',desc: 'Latidude',type: 'number'});                   															//	51.2993
                                        createState('Status.Speed-Test.data.client.lon',{name: 'Longitude',desc: 'Longitude',type: 'number'});                   															//	9.491
                                        createState('Status.Speed-Test.data.client.isp',{name: 'ISP',desc: 'Internet-Service-provide',type: 'string'});                 												//	Deutsche Telekom
                                        createState('Status.Speed-Test.data.client.isprating',{name: 'ISP-Rating',desc: 'ISP-Rating',type: 'number'});              														//	3
                                        createState('Status.Speed-Test.data.client.rating',{name: 'Rating',desc: 'Rating',type: 'number'});                 																	//	0
                                        createState('Status.Speed-Test.data.client.ispdlavg',{name: 'ISP-DL-AVG',desc: 'ISPDLAVG',type: 'number',unit:'Mbit/s'}); 															//	13.86
                                        createState('Status.Speed-Test.data.client.ispulavg',{name: 'ISP-UL-AVG',desc: 'ISPULAVG',type: 'number',unit:'Mbit/s'}); 															//	3.108
                                        
                                        createState('Status.Speed-Test.data.server.host',{name: 'Host',desc: 'Hostname des Servers',type: 'string'});                													//	speedtest.hillcom.de
                                        createState('Status.Speed-Test.data.server.lat',{name: 'Server-Latitude',desc: 'Latitude des Serverstandortes',type: 'number'});                   						//	50.7511
                                        createState('Status.Speed-Test.data.server.lon',{name: 'Server-Longitude',desc: 'Longitude des Serverstandortes',type: 'number'});                   		 			//	9.2711
                                        createState('Status.Speed-Test.data.server.location',{name: 'Server-Location',desc: 'Server-Standort',type: 'string'});            											//	Alsfeld
                                        createState('Status.Speed-Test.data.server.country',{name: 'Server-Country',desc: 'Land',type: 'string'});             															//	Germany
                                        createState('Status.Speed-Test.data.server.cc',{name: 'Server-CC',desc: 'Länderkürzel',type: 'string'});                  														//	DE
                                        createState('Status.Speed-Test.data.server.sponsor',{name: 'Server-Sponsor',desc: 'Sponsor des Servers',type: 'string'});             										//	HillCom Solutions
                                        createState('Status.Speed-Test.data.server.distance',{name: 'DistanzToServer',desc: 'Distanz zum Server in km',type: 'number',unit:'km'});     								//	62.87
                                        createState('Status.Speed-Test.data.server.distanceMi',{name: 'DistanzToServerMeilen',desc: 'Distanz des Servers im Meilen',type: 'number',unit:'Meilen'});				//	39.06
                                        createState('Status.Speed-Test.data.server.ping',{name: 'Server-Ping',desc: 'Ping zum Server',type: 'number'});                         										//	117.8
                                        createState('Status.Speed-Test.data.server.id',{name: 'Server-ID',desc: 'Server ID',type: 'string'});                                                                  	//	65599
                                        
                                        
                                        function SpeedTest() {
                                        exec("speed-test --json --verbose", function(err, stdout, stderr) {
                                            if (err) {
                                               log(stderr,'error');
                                               return;
                                            }
                                        writeDP(stdout);
                                        
                                        });
                                        }
                                        
                                        function writeDP(jsonstring){
                                        
                                        	var objects = JSON.parse(jsonstring);
                                        	
                                        	var jsonStr = jsonstring;
                                        	//log (jsonStr);
                                        
                                        	var ping = objects.ping;
                                        	var download = objects.download;
                                        	var upload = objects.upload;
                                        
                                            //log ('Ping =' + ping);
                                            //log ('Download = ' + download);
                                            //log ('Upload = ' + upload);
                                        
                                        
                                        	var Speed_Download = objects.data.speeds.download;
                                        	var Speed_Upload = objects.data.speeds.upload;
                                        	var Speed_OriginalDownload = objects.data.speeds.originalDownload;
                                        	var Speed_OriginalUpload = objects.data.speeds.originalUpload;
                                        
                                            //log ('Speed_Download = ' + Speed_Download);
                                            //log ('Speed_Upload = ' + Speed_Upload);
                                            //log ('OriginalDownload = ' + Speed_OriginalDownload);
                                            //log ('OriginalUpload = ' + Speed_OriginalUpload);
                                        
                                        
                                        
                                        	var Client_IP = objects.data.client.ip;
                                        	var Client_lat = objects.data.client.lat;
                                        	var Client_lon = objects.data.client.lon;
                                        	var Client_isp = objects.data.client.isp;
                                        	var Client_isprating = objects.data.client.isprating;
                                        	var Client_rating = objects.data.client.rating;
                                        	var Client_ispdlavg = objects.data.client.ispdlavg;
                                        	var Client_ispulavg = objects.data.client.ispulavg;
                                        
                                        	var Server_host = objects.data.server.host;
                                        	var Server_lat = objects.data.server.lat;
                                        	var Server_lon = objects.data.server.lon;
                                        	var Server_location = objects.data.server.location;
                                        	var Server_country = objects.data.server.country;
                                        	var Server_cc = objects.data.server.cc;
                                        	var Server_sponsor = objects.data.server.sponsor;
                                        	var Server_distance = objects.data.server.distance;
                                        	var Server_distanceMi = objects.data.server.distanceMi;
                                        	var Server_ping = objects.data.server.ping;
                                        	var Server_id = objects.data.server.id;
                                        
                                           setState(instanz + pfad + "json",jsonStr);
                                        
                                           setState(instanz + pfad + "ping",ping);
                                           setState(instanz + pfad + "download",download);
                                           setState(instanz + pfad + "upload",upload);
                                        
                                           setState(instanz + pfad + "data.speeds.download",Speed_Download);
                                           setState(instanz + pfad + "data.speeds.upload",Speed_Upload);
                                           setState(instanz + pfad + "data.speeds.orginalDownload",Speed_OriginalDownload);
                                           setState(instanz + pfad + "data.speeds.orginalUpload",Speed_OriginalUpload);
                                        
                                           setState(instanz + pfad + "data.client.ip",Client_IP);
                                           setState(instanz + pfad + "data.client.lat",Client_lat);
                                           setState(instanz + pfad + "data.client.lon",Client_lon);
                                           setState(instanz + pfad + "data.client.isp",Client_isp);
                                           setState(instanz + pfad + "data.client.isprating",Client_isprating);
                                           setState(instanz + pfad + "data.client.rating",Client_rating);
                                           setState(instanz + pfad + "data.client.ispdlavg",Client_ispdlavg);
                                           setState(instanz + pfad + "data.client.ispulavg",Client_ispulavg);
                                        
                                        
                                           setState(instanz + pfad + "data.server.host",Server_host);
                                           setState(instanz + pfad + "data.server.lat",Server_lat);
                                           setState(instanz + pfad + "data.server.lon",Server_lon);
                                           setState(instanz + pfad + "data.server.location",Server_location);
                                           setState(instanz + pfad + "data.server.country",Server_country);
                                           setState(instanz + pfad + "data.server.cc",Server_cc);
                                           setState(instanz + pfad + "data.server.sponsor",Server_sponsor);
                                           setState(instanz + pfad + "data.server.distance",Server_distance);
                                           setState(instanz + pfad + "data.server.distanceMi",Server_distanceMi);
                                           setState(instanz + pfad + "data.server.ping",Server_ping);
                                           setState(instanz + pfad + "data.server.id",Server_id);
                                        
                                        }
                                        
                                        
                                        // regelmässige Wiederholungen
                                        // -----------------------------------------------------------------------------
                                        schedule(cronStr, SpeedTest);
                                        
                                        1 Reply Last reply Reply Quote 1
                                        • K
                                          Kueppert @pix last edited by

                                          @pix sagte in Script für einen SpeedTest über speedtest.net:

                                          /* Speed-Test
                                          ! SpeedTest mit Ausgabe von Down- / Uploadgeschwindigkeit und Ping
                                          http://forum.iobroker.net/viewtopic.php?f=21&t=4170
                                          ! Erstellt 10.11.2016 by Cybertron
                                          angepasst 14.03.2017 by Pix
                                          20.03.2017 Unit ms für Datenpunkt ping (danke 0018)
                                          ! Installation:
                                          npm install --global speed-test
                                          ! Aufruf:
                                          speed-test --json --verbose
                                          ! Beispiel-Ausgabe:
                                          {"ping":118,"download":2.2,"upload":2.2,"data":{"speeds":{"download":2.179,"upload":2.209,"originalDownload":239941,"originalUpload":242389},
                                          "client":{"ip":"xxx.xxx.xxx.xxx","lat":51.2993,"lon":9.491,"isp":"Deutsche Telekom","isprating":3,"rating":0,"ispdlavg":13.86,"ispulavg":3.108},
                                          "server":{"host":"speedtest.hillcom.de","l

                                          Huhu PIX,
                                          das Skript ist im neuen Forum leider total kaputt gegangen. Das Skript von aleks-83 startet bei mir leider nicht. Wollte daher nochmal deines ausprobieren um sicher zu gehen, dass es nicht an meinem JS liegt...danke.

                                          1 Reply Last reply Reply Quote 0
                                          • P
                                            pix last edited by

                                            Hallo,

                                            es nervt mittlerweile, dass man die alten Skripte nicht mehr einfach verwenden/kopieren kann.
                                            Das neue Forum hat mich bisher mehr Zeit gekostet, als es gespart hat.

                                            @Kueppert Du kannst natürlich nix dafür. Hier der Code vom genannten Post nochmal zusammenkopiert, falsche Zeichen entfernt und durch den Beautifier gejagt:

                                            /* Speed-Test
                                            SpeedTest mit Ausgabe von Down- / Uploadgeschwindigkeit und Ping
                                            http://forum.iobroker.net/viewtopic.php?f=21&t=4170
                                            Erstellt 10.11.2016 by Cybertron
                                            angepasst 14.03.2017 by Pix
                                            20.03.2017 Unit ms für Datenpunkt ping (danke 0018)
                                            Installation:
                                            npm install --global speed-test
                                            Aufruf:
                                            speed-test --json --verbose
                                            Beispiel-Ausgabe:
                                            {"ping":118,"download":2.2,"upload":2.2,"data":{"speeds":{"download":2.179,"upload":2.209,"originalDownload":239941,"originalUpload":242389},
                                            "client":{"ip":"xxx.xxx.xxx.xxx","lat":51.2993,"lon":9.491,"isp":"Deutsche Telekom","isprating":3,"rating":0,"ispdlavg":13.86,"ispulavg":3.108},
                                            "server":{"host":"speedtest.hillcom.de","lat":50.7511,"lon":9.2711,"location":"Alsfeld","country":"Germany","cc":"DE","sponsor":"HillCom Solutions",
                                            "distance":62.87,"distanceMi":39.06,"ping":117.8,"id":"6599"}}}
                                            */
                                            var logging = true;
                                            var instanz = 'javascript.' + instance + '.';
                                            var pfad = 'Speed-Test.';
                                            var cronStr = "29,59 * * * *";
                                            
                                            function createStates() {
                                                // Allgemein
                                                createState(pfad + 'json', {
                                                    name: 'JSON',
                                                    desc: 'JSON Ausgabe',
                                                    type: 'string',
                                                    role: 'json'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'json erstellt');
                                                });
                                                createState(pfad + 'ping', {
                                                    name: 'Ping',
                                                    desc: 'Ping',
                                                    type: 'number',
                                                    unit: 'ms',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'ping erstellt');
                                                });
                                            
                                                createState(pfad + 'forceRefresh', {
                                                    name: 'aktualisieren',
                                                    desc: 'Werte neu einlesen',
                                                    type: 'boolean',
                                                    def: false,
                                                    role: 'indicator'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'forceRefresh erstellt');
                                                });
                                            
                                                // Speed
                                                createState(pfad + 'data.speeds.download', {
                                                    name: 'Download',
                                                    desc: 'Downloadgeschwindigkeit (Mbit/s)',
                                                    type: 'number',
                                                    unit: 'Mbit/s',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.download erstellt');
                                                });
                                                createState(pfad + 'data.speeds.upload', {
                                                    name: 'Upload',
                                                    desc: 'Uploadgeschwindigkeit (Mbit/s)',
                                                    type: 'number',
                                                    unit: 'Mbit/s',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.upload erstellt');
                                                });
                                                createState(pfad + 'data.speeds.orginalDownload', {
                                                    name: 'OrginalDownload',
                                                    desc: 'Downloadgeschwindigkeit (bit/s)',
                                                    type: 'number',
                                                    unit: 'bit/s',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.original Download erstellt');
                                                });
                                                createState(pfad + 'data.speeds.orginalUpload', {
                                                    name: 'OrginalUpload',
                                                    desc: 'Uploadgeschwindigkeit (bit/s)',
                                                    type: 'number',
                                                    unit: 'bit/s',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.speeds.originalUpload erstellt');
                                                });
                                                // Client
                                                createState(pfad + 'data.client.ip', {
                                                    name: 'IP',
                                                    desc: 'Öffentliche IP-Adresse',
                                                    type: 'string',
                                                    role: 'text'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.client.ip erstellt');
                                                });
                                                createState(pfad + 'data.client.lat', {
                                                    name: 'Latitude',
                                                    desc: 'Latidude',
                                                    type: 'number', // ##########################
                                                    unit: '°',
                                                    role: 'value.gps.latitude'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.client.lat erstellt');
                                                });
                                                createState(pfad + 'data.client.lon', {
                                                    name: 'Longitude',
                                                    desc: 'Longitude',
                                                    type: 'number', // ##########################
                                                    unit: '°',
                                                    role: 'value.gps.longitude'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.client.lomg erstellt');
                                                });
                                                createState(pfad + 'data.client.isp', {
                                                    name: 'ISP',
                                                    desc: 'Internet-Service-provider',
                                                    type: 'string',
                                                    role: 'text'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.client.isp erstellt');
                                                });
                                            
                                                createState(pfad + 'data.client.isprating', {
                                                    name: 'ISP-Rating',
                                                    desc: 'ISP-Rating',
                                                    type: 'number',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.client.isprating erstellt');
                                                });
                                            
                                                createState(pfad + 'data.client.rating', {
                                                    name: 'Rating',
                                                    desc: 'Rating',
                                                    type: 'number',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.client.rating erstellt');
                                                });
                                            
                                                createState(pfad + 'data.client.ispdlavg', {
                                                    name: 'ISP-DL-AVG',
                                                    desc: 'ISPDLAVG',
                                                    type: 'number',
                                                    unit: 'Mbit/s',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.client.ispdlavg erstellt');
                                                });
                                            
                                                createState(pfad + 'data.client.ispulavg', {
                                                    name: 'ISP-UL-AVG',
                                                    desc: 'ISPULAVG',
                                                    type: 'number',
                                                    unit: 'Mbit/s',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.client.ispulavg erstellt');
                                                });
                                            
                                                // Server
                                                createState(pfad + 'data.server.host', {
                                                    name: 'Host',
                                                    desc: 'Hostname des Servers',
                                                    type: 'string',
                                                    role: 'text'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.host erstellt');
                                                });
                                            
                                            
                                                createState(pfad + 'data.server.lat', {
                                                    name: 'Server-Latitude',
                                                    desc: 'Latitude des Serverstandortes',
                                                    type: 'number', // ##########################
                                                    unit: '°',
                                                    role: 'value.gps.latitude'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.lat erstellt');
                                                });
                                            
                                                createState(pfad + 'data.server.lon', {
                                                    name: 'Server-Longitude',
                                                    desc: 'Longitude des Serverstandortes',
                                                    type: 'number', // ##########################
                                                    unit: '°',
                                                    role: 'value.gps.longitude'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.lon erstellt');
                                                });
                                            
                                                createState(pfad + 'data.server.location', {
                                                    name: 'Server-Location',
                                                    desc: 'Server-Standort',
                                                    type: 'string',
                                                    role: 'text.city'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.location erstellt');
                                                });
                                            
                                                createState(pfad + 'data.server.country', {
                                                    name: 'Server-Country',
                                                    desc: 'Land',
                                                    type: 'string',
                                                    role: 'text.country'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.country erstellt');
                                                });
                                            
                                                createState(pfad + 'data.server.cc', {
                                                    name: 'Server-CC',
                                                    desc: 'Länderkürzel',
                                                    type: 'string',
                                                    role: 'text'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.cc erstellt');
                                                });
                                            
                                                createState(pfad + 'data.server.sponsor', {
                                                    name: 'Server-Sponsor',
                                                    desc: 'Sponsor des Servers',
                                                    type: 'string',
                                                    role: 'text'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.sponsor erstellt');
                                                });
                                            
                                                createState(pfad + 'data.server.distance', {
                                                    name: 'DistanzToServer',
                                                    desc: 'Distanz zum Server in km',
                                                    type: 'number',
                                                    unit: 'km',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.distance erstellt');
                                                });
                                            
                                                createState(pfad + 'data.server.distanceMi', {
                                                    name: 'DistanzToServerMeilen',
                                                    desc: 'Distanz des Servers im Meilen',
                                                    type: 'number',
                                                    unit: 'Meilen',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.distanceMi erstellt');
                                                });
                                            
                                                createState(pfad + 'data.server.ping', {
                                                    name: 'Server-Ping',
                                                    desc: 'Ping zum Server',
                                                    type: 'number',
                                                    unit: 'ms',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.ping erstellt');
                                                });
                                            
                                                createState(pfad + 'data.server.id', {
                                                    name: 'Server-ID',
                                                    desc: 'Server ID',
                                                    type: 'number',
                                                    role: 'value'
                                                }, function() {
                                                    if (logging) log('Objekt ' + instanz + pfad + 'data.server.id erstellt');
                                                });
                                            
                                            }
                                            
                                            function SpeedTest() {
                                                exec("speed-test --json --verbose", function(err, stdout, stderr) {
                                                    if (err) {
                                                        log(stderr, 'error');
                                                        log('Speedtest Daten konnten nicht abgefragt werden', 'error');
                                                        return;
                                                    }
                                                    writeDP(stdout);
                                                });
                                            }
                                            
                                            function writeDP(jsonstring) {
                                                var objects = JSON.parse(jsonstring);
                                            
                                                var jsonStr = jsonstring;
                                                //log (jsonStr);
                                            
                                                var ping = objects.ping;
                                                var download = objects.download;
                                                var upload = objects.upload;
                                                //log ('Ping =' + ping);
                                                //log ('Download = ' + download);
                                                //log ('Upload = ' + upload);
                                                var Speed_Download = objects.data.speeds.download;
                                                var Speed_Upload = objects.data.speeds.upload;
                                                var Speed_OriginalDownload = objects.data.speeds.originalDownload;
                                                var Speed_OriginalUpload = objects.data.speeds.originalUpload;
                                                //log ('Speed_Download = ' + Speed_Download);
                                                //log ('Speed_Upload = ' + Speed_Upload);
                                                //log ('OriginalDownload = ' + Speed_OriginalDownload);
                                                //log ('OriginalUpload = ' + Speed_OriginalUpload);
                                                var Client_IP = objects.data.client.ip;
                                                var Client_lat = objects.data.client.lat;
                                                var Client_lon = objects.data.client.lon;
                                                var Client_isp = objects.data.client.isp;
                                                var Client_isprating = objects.data.client.isprating;
                                                var Client_rating = objects.data.client.rating;
                                                var Client_ispdlavg = objects.data.client.ispdlavg;
                                                var Client_ispulavg = objects.data.client.ispulavg;
                                                var Server_host = objects.data.server.host;
                                                var Server_lat = objects.data.server.lat;
                                                var Server_lon = objects.data.server.lon;
                                                var Server_location = objects.data.server.location;
                                                var Server_country = objects.data.server.country;
                                                var Server_cc = objects.data.server.cc;
                                                var Server_sponsor = objects.data.server.sponsor;
                                                var Server_distance = objects.data.server.distance;
                                                var Server_distanceMi = objects.data.server.distanceMi;
                                                var Server_ping = objects.data.server.ping;
                                                var Server_id = objects.data.server.id;
                                                setState(instanz + pfad + "json", jsonStr);
                                            
                                                setState(instanz + pfad + "ping", parseFloat(ping));
                                                //setState(instanz + pfad + "download", parseFloat(download));
                                                //setState(instanz + pfad + "upload", parseFloat(upload));
                                            
                                                setState(instanz + pfad + "data.speeds.download", parseFloat(Speed_Download));
                                                setState(instanz + pfad + "data.speeds.upload", parseFloat(Speed_Upload));
                                                setState(instanz + pfad + "data.speeds.orginalDownload", parseFloat(Speed_OriginalDownload));
                                                setState(instanz + pfad + "data.speeds.orginalUpload", parseFloat(Speed_OriginalUpload));
                                                setState(instanz + pfad + "data.client.ip", Client_IP);
                                                setState(instanz + pfad + "data.client.lat", parseFloat(Client_lat));
                                                setState(instanz + pfad + "data.client.lon", parseFloat(Client_lon));
                                                setState(instanz + pfad + "data.client.isp", Client_isp);
                                                setState(instanz + pfad + "data.client.isprating", parseFloat(Client_isprating));
                                                setState(instanz + pfad + "data.client.rating", parseFloat(Client_rating));
                                                setState(instanz + pfad + "data.client.ispdlavg", parseFloat(Client_ispdlavg));
                                                setState(instanz + pfad + "data.client.ispulavg", parseFloat(Client_ispulavg));
                                                setState(instanz + pfad + "data.server.host", Server_host);
                                                setState(instanz + pfad + "data.server.lat", parseFloat(Server_lat));
                                                setState(instanz + pfad + "data.server.lon", parseFloat(Server_lon));
                                                setState(instanz + pfad + "data.server.location", Server_location);
                                                setState(instanz + pfad + "data.server.country", Server_country);
                                                setState(instanz + pfad + "data.server.cc", Server_cc);
                                                setState(instanz + pfad + "data.server.sponsor", Server_sponsor);
                                                setState(instanz + pfad + "data.server.distance", parseFloat(Server_distance));
                                                setState(instanz + pfad + "data.server.distanceMi", parseFloat(Server_distanceMi));
                                                setState(instanz + pfad + "data.server.ping", parseFloat(Server_ping));
                                                setState(instanz + pfad + "data.server.id", parseFloat(Server_id));
                                                setState(instanz + pfad + 'forceRefresh', false);
                                                log('Speedtest Daten aktualisiert');
                                            }
                                            
                                            // regelmässige Wiederholungen
                                            schedule(cronStr, SpeedTest);
                                            
                                            // einmaliger Start bei Skriptstart
                                            createStates();
                                            
                                            setTimeout(SpeedTest, 1500);
                                            
                                            // Start beim Setzen auf true
                                            on(instanz + pfad + 'forceRefresh', function(obj) {
                                                if (!obj.state.ack && obj.state.val) SpeedTest();
                                            });
                                            

                                            Gruß
                                            Pix

                                            sigi234 K 2 Replies Last reply Reply Quote 3
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            821
                                            Online

                                            31.7k
                                            Users

                                            79.8k
                                            Topics

                                            1.3m
                                            Posts

                                            javascript
                                            57
                                            177
                                            32976
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo